传递可选参数

查询参数允许您将可选参数传递到路由,例如分页信息。

例如,在具有分页列表的路由上,网址可能如下所示,表示我们已加载第二个网页:

localhost:3000/product-list?page=2

查询参数和路由参数之间的关键区别在于路由参数对于确定路由是必要的,而查询参数是可选的。

传递查询参数

使用[queryParams]指令和[routerLink]来传递查询参数。例如:

  1. <a [routerLink]="['product-list']" [queryParams]="{ page: 99 }">Go to Page 99</a>

或者,我们可以使用Router服务通过JS跳转:

  1. goToPage(pageNum) {
  2. this.router.navigate(['/product-list'], { queryParams: { page: pageNum } });
  3. }

读取查询参数

类似于读取 路由参数Router服务返回一个Observable,我们可以订阅读取查询参数:

  1. import { Component } from '@angular/core';
  2. import { ActivatedRoute, Router } from '@angular/router';
  3. @Component({
  4. selector: 'product-list',
  5. template: `<!-- Show product list -->`
  6. })
  7. export default class ProductList {
  8. constructor(
  9. private route: ActivatedRoute,
  10. private router: Router) {}
  11. ngOnInit() {
  12. this.sub = this.route
  13. .queryParams
  14. .subscribe(params => {
  15. // Defaults to 0 if no query param provided.
  16. this.page = +params['page'] || 0;
  17. });
  18. }
  19. ngOnDestroy() {
  20. this.sub.unsubscribe();
  21. }
  22. nextPage() {
  23. this.router.navigate(['product-list'], { queryParams: { page: this.page + 1 } });
  24. }
  25. }

View Example

See Official Documentation on Query Parameters