@H_403_0@
基础知识
@H_403_0@1.const routes: RouterConfig = [
{ path: 'crisis-center',component: CrisisCenterComponent },{ path: 'heroes',component: HeroListComponent },{ path: 'hero/:id',component: HeroDetailComponent },{ path: '**',component: PageNotFoundComponent }
];
@H_403_0@RouterConfig是一个路由数组,它决定如何导航。每个Route会把一个 URL 的 path映射到一个组件。
@H_403_0@path不能使用斜杠/开头。路由器会为我们解析和生成URL。
@H_403_0@第三个路由中的id是一个路由参数的 token。
@H_403_0@第四个路由中的**代表路由是一个通配符路径。如果当前无法匹配上我们配置过的任何一个路径,路由器就会匹配上这一个,类似于 switch中的default。当需要显示 404 页面,该特性非常有用。
@H_403_0@我们将配置好的routes数组传给provideRouter()函数,这个函数返回一个经过配置的 Router服务提供商
@H_403_0@最后通过 appRouterProviders数组导出这个提供商,以便在main.ts中简单的注册路由器依赖。
在 main.ts中的bootstrap函数中注册路由器的提供商。
@H_403_0@{ path: 'crisis-center',component: CrisisCenterComponent },{ path: 'heroes',component: HeroListComponent },{ path: 'hero/:id',component: HeroDetailComponent },{ path: '**',component: PageNotFoundComponent }
];
export const appRouterProviders = [
provideRouter(routes)
];
main.ts
bootstrap(AppComponent,[
appRouterProviders
])
.catch(err => console.error(err));
@H_403_0@4.appRouterProviders
])
.catch(err => console.error(err));
如果routerLink想要绑定动态信息,我们就可以把它绑定到一个能够返回路由链接数组的模板表达式上。路由器最终会把此数组解析成一个 URL 和一个组件视图。
我们还可以往中添加一个routerLinkActive指令,用于在相关的routerLink被激活时所在元素添加或移除CSS类。该指令可以直接添加到该元素上,也可以直接添加到其父元素上。
AppComponent模板
Component Router
`,
@H_403_0@6.路由器状态
@H_403_0@在每个导航的生命周期完成时,路由器会构建出一个 ActivatedRoute组成的树,它表示路由器的当前状态。我们可以在应用中任何使用 Router服务及其 routerState属性来访问当前的RouterState值。
@H_403_0@7.ROUTER_DIRECTIVES
@H_403_0@RouterLink、RouterLinkActive和RouterOutlet是ROUTER_DIRECTIVES集合中的指令,所以需要在@Component元数据中加入到directives数组中。
@H_403_0@directives: [ROUTER_DIRECTIVES]
@H_403_0@以上就是对Angular2 (RC4) 路由与导航的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!