Angular2 小贴士 RouterLink 导航
AngularJS的路由一直是学习的一大难点,我们只能边看边学边掌握,边看边学边推翻。今天我们来看一下在angular2中通过routerLink实现导航的几种方式,以及各自的优缺点。 Angular2的路由模块来自@angular/router,这不包含在angular2的核心模块中。所以如果我们想要学习angular2的路由功能,必须导入该模块。 我们自己的最佳实践就是不断的推翻自己的过程,痛苦并痛苦着。 我自己总结的几种导航方式: 1 <a routerLink='/dashboard/home' routerLinkActive='active'>Home1</a> 2 <a routerLink='/dashboard/home' [routerLinkActive]="['active']">Home2</a> 3 <a routerLink='../home' routerLinkActive="active">Home 2.2 </a> 4 <a [routerLink]="['/dashboard/home']" [routerLinkActive]="['active']">Home3</a> 5 <a [routerLink]="['../home']" [routerLinkActive]="['active']">Home4</a> 6 <a [routerLink]="['../home']" [routerLinkActive]="['active']">Home5</a> 7 8 <a [routerLinkActive]="['active']" (click)="onSelect()">Home6</a>
onSelect()方法: 1 import { Component,OnInit } from '@angular/core'; 2 import { Route,Router,ActivatedRoute,Params } from '@angular/router'; 3 import 'rxjs/add/operator/switchMap'; 4 5 @Component({ 6 templateUrl: './chart.component.html' 7 }) 8 9 export class ChartComponent implements OnInit { 10 constructor(private route: ActivatedRoute,private router: Router) { 11 12 } 13 14 ngOnInit() { 15 console.log(this.route.params['id']); 16 } 17 18 onSelect() { 19 this.router.navigate(['../home'],{relativeTo:this.route}); 20 } 21 } 现在我们来逐个分析一下这些可以导航的方式:
通过我们的简单分析,我们来看一下,我们一般会采用哪种方式进行导航? 一般我们不会直接定义绝对路径的方式进行导航,这有很多原因:1.绝对路径很长的时候很容易写错 2.不容易移植。 那么采用相对路径,其实也存在很多问题:1.由于angular2的组件可复用,并且可嵌套,我们如果要导航到一个组件,由于我们的父子关系,可能会出现导航相对路径不一致的情况。 由于angular2的路由存在嵌套关系,并且可以重复嵌套相同组件到不同层级,这就导致我们的组件复用度远没有我们想象的那么广泛。 其实就我个人而言,我更倾向于采用一个服务的方式提供绝对路径前缀,我们在导航时动态的拼接成绝对路径的方式。 如果你有更好的方式,欢饮评论提供建议。 路由动画、路由拦截等其他功能我们下次再聊。再看一遍睡觉 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |