codecamp

Angular9 路由器参考手册

下面的部分重点介绍了一些路由器的核心概念。

路由器导入

Angular 的 Router 是一个可选服务,它为指定的 URL 提供特定的组件视图。它不是 Angular 核心的一部分,因此它位于自己的包 @angular/router 中。

从任何其它的 Angular 包中导入你需要的东西。

Path:"src/app/app.module.ts (import)" 。

import { RouterModule, Routes } from '@angular/router';

有关浏览器 URL 风格的更多信息,请参阅 LocationStrategy 和浏览器的网址样式

配置

带路由的 Angular 应用中有一个 Router 服务的单例实例。当浏览器的 URL 发生变化时,该路由器会查找相应的 Route,以便根据它确定要显示的组件。

在配置之前,路由器没有任何路由。下面的例子创建了五个路由定义,通过 RouterModule.forRoot() 方法配置路由器,并把结果添加到 AppModuleimports 数组中。

Path:"src/app/app.module.ts (excerpt)" 。

const appRoutes: Routes = [
  { path: 'crisis-center', component: CrisisListComponent },
  { path: 'hero/:id',      component: HeroDetailComponent },
  {
    path: 'heroes',
    component: HeroListComponent,
    data: { title: 'Heroes List' }
  },
  { path: '',
    redirectTo: '/heroes',
    pathMatch: 'full'
  },
  { path: '**', component: PageNotFoundComponent }
];


@NgModule({
  imports: [
    RouterModule.forRoot(
      appRoutes,
      { enableTracing: true } // <-- debugging purposes only
    )
    // other imports here
  ],
  ...
})
export class AppModule { }

appRoutes 路由数组描述了如何导航。把它传给模块的 imports 数组中的 RouterModule.forRoot() 方法来配置路由器。

每个 Route 都会把一个 URL path 映射到一个组件。路径中没有前导斜杠。路由器会为你解析并构建最终的 URL,这样你就可以在应用视图中导航时使用相对路径和绝对路径了。

第二个路由中的 :id 是路由参数的令牌。在像 "/hero/42" 这样的 URL 中,“42”是 id 参数的值。相应的 HeroDetailComponent 用这个值来查找并显示 id 为 42 的英雄。

第三个路由中的 data 属性是存放与该特定路由关联的任意数据的地方。每个激活的路由都可以访问 data 属性。可以用它来存储页面标题,面包屑文本和其它只读静态数据等项目。你可以尝试使用解析器守卫来检索动态数据。

第四个路由中的空路径表示该应用的默认路径 - 当 URL 中的路径为空时通常要去的地方,就像它在刚进来时一样。这个默认路由重定向到了 "/heroes" 这个 URL 的路由,因此会显示 HeroesListComponent

如果你需要查看导航生命周期中发生了什么事件,可以把 enableTracing 选项作为路由器默认配置的一部分。这会把每个导航生命周期中发生的每个路由器事件都输出到浏览器控制台中。enableTracing 只会用于调试目的。你可以把 enableTracing: true 选项作为第二个参数传给 RouterModule.forRoot() 方法。

路由出口

RouterOutlet 是一个来自路由器库的指令,虽然它的用法像组件一样。它充当占位符,用于在模板中标记出路由器应该显示把该组件显示在那个出口的位置。

<router-outlet></router-outlet>
<!-- Routed components go here -->

对于上面的配置,当这个应用的浏览器 URL 变为 "/heroes" 时,路由器就会把这个 URL 与路由路径 "/heroes" 匹配,并把 HeroListComponent 作为兄弟元素显示在宿主组件模板中的 RouterOutlet 下方。

路由链接

要想通过某些用户操作(比如单击一下 a 标签)进行导航,请使用 RouterLink

考虑下面的模板:

Path:"src/app/app.component.html " 。

<h1>Angular Router</h1>
<nav>
  <a routerLink="/crisis-center" routerLinkActive="active">Crisis Center</a>
  <a routerLink="/heroes" routerLinkActive="active">Heroes</a>
</nav>
<router-outlet></router-outlet>

a 标签上的 RouterLink 指令让路由器可以控制这些元素。导航路径是固定的,所以你可以给 routerLink 赋值一个字符串(“一次性”绑定)。

如果导航路径更加动态,你可以给它绑定到一个模板表达式,该表达式要返回一个链接参数数组。路由器会把该数组解析成一个完整的 URL

活动路由链路

RouterLinkActive 指令会根据当前的 RouterState 切换活动 RouterLink 上所绑定的 CSS 类。

在每个 a 标签上,你会看到一个到 RouterLinkActive 指令的属性绑定,就像 routerLinkActive="..."。

等号 = 右侧的模板表达式,包含一个以空格分隔的 CSS 类字符串,当这个链接处于活动状态时,路由器就会加上这些字符串(并在非活动状态时删除)。你可以把 RouterLinkActive 指令设置成一串类的字符串,比如 [routerLinkActive]="'active fluffy'",也可以把它绑定到一个返回这样一个字符串的组件属性上。

活动路由链接会级联到路由树的每个级别,这样父路由和子路由链接就可以同时处于活动状态。要覆盖这种行为,你可以用 { exact: true } 表达式绑定到 [routerLinkActiveOptions] 输入绑定。使用 { exact: true } 之后,给定的 RouterLink 只有在 URL 与当前 URL 完全匹配时才会激活。

路由器状态

每个成功的导航生命周期结束后,路由器都会构建一个 ActivatedRoute 对象树,它构成了路由器的当前状态。你可以从任何地方使用应用的 Router 服务和 routerState 属性来访问当前的 RouterState

RouterState 中的每个 ActivatedRoute 都提供了向上或向下遍历路由树的方法,用于从父路由、子路由和兄弟路由中获取信息。

激活路由

路由的路径和参数可以通过注入名为 ActivatedRoute 的路由服务获得。它提供了大量有用的信息,包括:

属性 说明
url 一个路由路径的 Observable,是一个由路由路径的各个部分组成的字符串数组。
data 包含提供给当前路由的 data 对象的 Observable。 也包含任何由解析守卫解析出的值。
paramMap 一个包含该路由的必要参数和可选参数 map 的 Observable。 这个 map 支持从同一个参数中获得单个或多个值。
queryParamMap 一个包含适用于所有路由的查询参数 map 的 Observable。 这个 map 支持从同一个查询参数中获得单个或多个值。
fragment 一个适用于所有路由的 URL 片段的 Observable
outlet 用来渲染该路由的 RouterOutlet 的名字。 对于无名出口,这个出口的名字是 primary
routeConfig 包含原始路径的那个路由的配置信息。
parent 当该路由是子路由时,表示该路由的父级 ActivatedRoute
firstChild 包含该路由的子路由列表中的第一个 ActivatedRoute
children 包含当前路由下所有激活的子路由。

还有两个较旧的属性,但更推荐使用它们的替代品,因为它们可能会在以后的 Angular 版本中弃用。

- `params` :一个 `Observable`,它包含专属于该路由的必要参数和可选参数。请改用 `paramMap`。

- `queryParams`:一个包含可用于所有路由的查询参数的 `Observable`。请改用 `queryParamMap`。

路由器事件

Router 在每次导航过程中都会通过 Router.events 属性发出导航事件。这些事件的范围贯穿从导航开始和结束之间的多个时间点。导航事件的完整列表如下表所示。

路由事件 说明
NavigationStart 导航开始时触发的事件。
RouteConfigLoadStart 在 Router 惰性加载路由配置之前触发的事件。
RouteConfigLoadEnd 在某个路由已经惰性加载完毕时触发的事件。
RoutesRecognized 当路由器解析了 URL,而且路由已经识别完毕时触发的事件。
GuardsCheckStart 当路由器开始进入路由守卫阶段时触发的事件。
ChildActivationStart 当路由器开始激活某路由的子路由时触发的事件。
ActivationStart 当路由器开始激活某个路由时触发的事件。
GuardsCheckEnd 当路由器成功结束了路由守卫阶段时触发的事件。
ResolveStart 当路由器开始路由解析阶段时触发的事件。
ChildActivationEnd 当路由器成功激活某路由的子路由时触发的事件。
ResolveEnd 当路由器的路由解析阶段成功完成时触发的事件。
ActivationEnd 当路由器成功激活了某个路由时触发的事件。
NavigationEnd 当导航成功结束时触发的事件。
NavigationCancel 当导航被取消时触发的事件。 这可能在导航期间某个路由守卫返回了 false 或返回了 UrlTree 以进行重定向时发生。
NavigationError 当导航由于非预期的错误而失败时触发的事件。
Scroll 用来表示滚动的事件。

当启用了 enableTracing 选项时,Angular 会把这些事件都记录到控制台。有关筛选路由器导航事件的示例,请参阅 Angular 中的 Observables 一章的路由器部分。

路由器术语

这里是一些关键的 Router 术语及其含义:

路由器部件 含义
Router 为活动 URL 显示应用中的组件。 管理从一个组件到另一个的导航。
RouterModule 一个单独的 NgModule,它提供了一些必要的服务提供者和一些用于在应用视图间导航的指令。
Routes 定义一个路由数组,每一个条目都会把一个 URL 路径映射到组件。
Route 定义路由器如何基于一个 URL 模式导航到某个组件。 大部分路由都由一个路径和一个组件类组成。
RouterOutlet 该指令 (<router-outlet>) 用于指出路由器应该把视图显示在哪里。
RouterLink 用于将可点击的 HTML 元素绑定到某个路由的指令。单击带有 routerLink 指令且绑定到字符串或链接参数数组的元素,将触发导航。
RouterLinkActive 该指令会在元素上或元素内包含的相关 routerLink 处于活动/非活动状态时,从 HTML 元素上添加/移除类。
ActivatedRoute 一个提供给每个路由组件的服务,其中包含当前路由专属的信息,例如路由参数、静态数据、解析数据、全局查询参数和全局片段。
RouterState 路由器的当前状态,包括一棵当前激活路由的树以及遍历这棵路由树的便捷方法。
链接参数数组 一个由路由器将其解释为路由指南的数组。你可以将该数组绑定到 RouterLink 或将该数组作为参数传递给 Router.navigate 方法。
路由组件 一个带有 RouterOutlet 的 Angular 组件,可基于路由器的导航来显示视图。
Angular9 <base href>
Angular9 防范跨站脚本(XSS)攻击
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Anguler9 中文教程总览

Angular9 基础知识

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }