Angular2 为我们提供了名为Title的Service用于修改和获取页面标题,但是如果只是能够在每个页面的ngOnInit方法中为每个页面设置标题岂不是太low了,不符合Angular2高(zhuang)大(bi)的身影。我们想要的结果是在页面改变时能够动态地改变页面标题,如此最好的解决方案就是组合使用Router事件和Title Service。
Title Service
使用Service自然首先要将其引入,不过要注意Title Service并不在@angular/core中,而是在@angular/platform-browser中:
import { Title } from '@angular/platform-browser';
引入之后,自然要将其注入到当前组件中,而这通常利用constructor完成:
import { Title } from '@angular/platform-browser'; import {Component} from '@angular/core'; @Component({}) export class AppComponent { constructor(private titleService: Title) { // 使用this.title到处浪 } }
很显然,Title Service应该有某些操作页面标题的方法,不管通过查找文档还是查找源码我们都能很容易知道其只有两个方法:
- getTitle() 用于获取当前当前页面的标题
- setTitle(newTitle: String) 用于设置当前页面的标题
如果只是简单地静态地设置页面标题,则可以在ngOnInit方法中直接使用setTitle方法:
// import bala... @Component({}) export class AppComponent implements OnInit { constructor(private titleService: Title) { // 使用this.title到处浪 } ngOnInit() { this.titleService.setTitle('New Title Here'); } }
在ngOnInit中使用setTitle方法设置文档标题是较好的时机,当然也可以根据自己的需求在任意地方使用setTitle方法。
Router和Router事件
使用Router和使用Title Service流程基本一致,先引入后注入,不过要注意Router和Title Service类似并不位于@angular/core中,而是位于@angular/router中:
import { Title } from '@angular/platform-browser'; import {Component} from '@angular/core'; import {Router} from '@angular/router'; @Component({}) export class AppComponent { constructor(private titleService: Title, private router: Router) { // 使用this.title和this.router到处浪 } }
Router配置
Angular2中通过URL、Router和Component之间的对应关系进行页面之间的跳转,Router把浏览器中的URL看做一个操作指南,据此可导航到一个由客户端生成的视图,并可以把参数传给支撑视图的相应组件。所以我们需要定义路由表:
// import bala... export const rootRouterConfig: Routes = [ { path: '', redirectTo: 'home', pathMatch: 'full'}, { path: 'home', component: HomeComponent, data: {title: 'Home-Liu'} }, { path: 'about', component: AboutComponent, data: {title: 'About-Liu'} }, { path: 'github', component: RepoBrowserComponent, children: [ { path: '', component: RepoListComponent, data: {title: 'GitHub List'} }, { path: ':org', component: RepoListComponent, children: [ { path: '', component: RepoDetailComponent, data: {title: 'Repo'} }, { path: ':repo', component: RepoDetailComponent, data: {title: 'RepoDetail'} } ] }] }, { path: 'contact', component: ContactComponent, data: {title: 'Contact-Liu'} } ];
注意路径和组件之间的对应关系,并且为了能够在Router事件中获取到页面标题,我们在路由表中,为一些页面提供了数据data,并在data中设置了表示页面标题的title属性。
Router事件
利用Router事件我们就可以实现动态改变页面标题的目的,不过放置的位置很重要,我们这里选择在AppComponent的ngOnInit方法中利用subscribe订阅Router事件,因为AppComponent是根组件,所以能够订阅所有Router事件:
ngOnInit() { this.router.events .subscribe((event) => { console.log(event); // 包括NavigationStart, RoutesRecognized, NavigationEnd }); }
当然我们这里这对NavigationEnd事件感兴趣:
import {ActivatedRoute} from '@angular/router'; // import bala... // other codes ngOnInit() { this.router.events .subscribe((event) => { if (event instanceof NavigationEnd) { console.log('NavigationEnd:', event); } }); }
当然使用这种判断筛选的方式并没有错,但是在现在的前端世界里显得不够优雅,我们应该使用RxJS中的filter达到我们的目的:
import 'rxjs/add/operator/filter'; // import bala... // other codes ngOnInit() { this.router.events .filter(event => event instanceof NavigationEnd) // 筛选原始的Observable:this.router.events .subscribe((event) => { console.log('NavigationEnd:', event); }); }
当然,我们如果想要动态改变某个页面的标题,就需要获取到当前被展示的页面对应的路由信息,而这可以通过ActivatedRoute得到,其使用方式和Title Service及Router类似,不再赘述:
import { Title } from '@angular/platform-browser'; import {Component, OnInit} from '@angular/core'; import {Router, NavigationEnd, ActivatedRoute} from '@angular/router'; import 'rxjs/add/operator/filter'; import 'rxjs/add/operator/map'; @Component({}) export class AppComponent implements OnInit { constructor(private titleService: Title, private router: Router, private activatedRoute: ActivatedRoute) { // 使用this.title和this.router和this.activatedRoute到处浪 } ngOnInit() { this.router.events .filter(event => event instanceof NavigationEnd) .map(() => this.activatedRoute) // 将filter处理后的Observable再次处理 .subscribe((event) => { console.log('NavigationEnd:', event); }); } }
注意这里我们又使用了RxJS中的map来更优雅地达成我们目的。
看起来我们已经完(luo)成(suo)很多事情了,但是还不够,我们目前还没有处理子路由,即我们上文路由配置中的children属性,所以我们还需要遍历路由表以便获取到每一个页面对应的路由信息:
ngOnInit() { this.router.events .filter(event => event instanceof NavigationEnd) .map(() => this.activatedRoute) .map((route) => { while(route.firstChild) { route = router.firstChild; } return route; }) .subscribe((event) => { console.log('NavigationEnd:', event); }); }
最后,我们还需要获取到我们在路由表中为每个路由传入的data信息,然后再利用Title Service设置页面标题:
ngOnInit() { this.router.events .filter(event => event instanceof NavigationEnd) .map(() => this.activatedRoute) .map(route => { while (route.firstChild) route = route.firstChild; return route; }) .mergeMap(route => route.data) .subscribe((event) => this.titleService.setTitle(event['title'])); }
下面是完成的最终代码,或者也可以到GitHub上查看完整代码:
import { Component, OnInit } from '@angular/core'; import { Router, NavigationEnd, ActivatedRoute } from '@angular/router'; import { Title } from '@angular/platform-browser'; import 'rxjs/add/operator/filter'; import 'rxjs/add/operator/map'; import 'rxjs/add/operator/mergeMap'; @Component({...}) export class AppComponent implements OnInit { constructor( private router: Router, private activatedRoute: ActivatedRoute, private titleService: Title ) {} ngOnInit() { this.router.events .filter(event => event instanceof NavigationEnd) .map(() => this.activatedRoute) .map(route => { while (route.firstChild) route = route.firstChild; return route; }) .filter(route => route.outlet === 'primary') .mergeMap(route => route.data) .subscribe((event) => this.titleService.setTitle(event['title'])); } }
参考文档
Angular2 路由指导
Angualr2 ActivatedRoute文档
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]