Angular中的ActivatedRoute和Router原理是什么

其他教程   发布日期:2025年02月28日   浏览次数:143

这篇“Angular中的ActivatedRoute和Router原理是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Angular中的ActivatedRoute和Router原理是什么”文章吧。

Angular中的ActivatedRoute和Router解释

在Angular中,

  1. ActivatedRoute
  1. Router
是两个核心的路由服务。他们都提供可以用来检查和操作当前页面路由信息的方法和属性。

ActivatedRoute

  1. ActivatedRoute
是一个保存关于当前路由状态(如路由参数、查询参数以及其他数据)的对象。 它可以让开发人员从路由器中访问路由参数和查询参数。

ActivatedRoute是路由事件数据的载体。 这包括在导航期间收集的静态和动态段以及查询参数、Fragment等等。

例如,对于这个路由:

  1. { path: 'product/:id', component: ProductDetailComponent }

通过获取

  1. ActivatedRoute
,我们可以轻松地访问
  1. id
值:
  1. import { Component } from '@angular/core';
  2. import { ActivatedRoute } from '@angular/router';
  3. @Component({
  4. selector: 'app-product-detail',
  5. template: 'Product Details Component'
  6. })
  7. export class ProductDetailComponent implements OnInit {
  8. constructor(private route: ActivatedRoute) {}
  9. ngOnInit() {
  10. const id = +this.route.snapshot.paramMap.get('id');
  11. // ...
  12. }
  13. }

在上面的代码示例中,

  1. ActivatedRoute
通过注入该服务作为构造函数的参数而获取。接下来,我们只需使用快照对象(即
  1. this.route.snapshot
)就可以快速访问路由参数。要获取参数的特定值,可以使用get方法访问params属性,该方法采用一个字符串参数并返回一个字符串:
  1. const id = +this.route.snapshot.paramMap.get('id');

这里的加号意味着我们将结果转换为数字类型。

另一种访问路由参数的方法是通过订阅

  1. paramMap
可观察值。subscribe`方法定义给observable带来副作用,就像任何** RxJS **observable一样:
  1. this.route.paramMap.subscribe(params => {
  2. const id = +params.get('id');
  3. // ...
  4. });

这种方式允许动态更改URL。(你的组件不需要重新创建。)

Router

  1. Router
通过向前和向后导航和路由装置提供了一种明显且简单的编程API,同时仍然保留完全配置的强大能力。

路由器是一个抽象的概念,它用于选择输入URL,并将其转换为经过测试的规则来获取特定组件。 在Angular中,路由器是NgModule中的引导项之一。 路由器设置可能看起来非常困难,但是一旦了解了基本情况,它们就会感到自然。

基本导航

首先,我们根据常规用法配置

  1. Routes
数组:
  1. // app-routing.module.ts file
  2. import { Routes, RouterModule } from '@angular/router';
  3. import { HomeComponent } from './home/home.component';
  4. import { ProductListComponent } from './product-list/product-list.component';
  5. import { ProductDetailComponent } from './product-detail/product-detail.component';
  6. const routes: Routes = [
  7. { path: '', component: HomeComponent },
  8. { path: 'products', component: ProductListComponent },
  9. { path: 'products/:id', component: ProductDetailComponent }
  10. ];
  11. @NgModule({
  12. imports: [RouterModule.forRoot(routes)],
  13. exports: [RouterModule]
  14. })
  15. export class AppRoutingModule { }

我们设定了三个路由:空路径(主页),产品列表和特定ID的产品。 每个路径都与对应的组件相关联。

然后,我们在模板或组件类中安排具有相应路由声明的链接:

  1. <!-- home.component.html -->
  2. <a routerLink="/">Home</a>
  3. <a routerLink="/products">Product List</a>
  4. <!-- product-list.component.html -->
  5. <ul>
  6. <li *ngFor="let product of products">
  7. <a [routerLink]="['/products', product.id]">{{ product.name }}</a>
  8. </li>
  9. </ul>
  10. <!-- product-detail.component.html -->
  11. <h3>Product Detail</h3>
  12. <p>{{ product }}</p>

在上面的所有代码示例中,我们使用了

  1. routerLink
指令完成路由导航。现在,当用户点击链接时,路由器会根据路径加载相应的组件并在指令的位置动态渲染该组件。

以上就是Angular中的ActivatedRoute和Router原理是什么的详细内容,更多关于Angular中的ActivatedRoute和Router原理是什么的资料请关注九品源码其它相关文章!