URLバーからリンクをクリックまたは参照するたびに、ページのタイトルを変更したい。 Angularルートを使用してそれを変更する方法?私はangularバージョン4およびangular cli。
_@angular/platefor-browser
_を使用してsetTitle()
:を使用できます
_import { Title } from '@angular/platform-browser';
@Component({
selector: 'your-component',
})
export class YourComponent implements onInit {
constructor(private title: Title) {}
ngOnInit() {
this.title.setTitle('Title for this component');
}
}
_
「タイトル」をデータとしてルートに渡す必要があります
const routes: Routes = [{
path: 'calendar',
component: CalendarComponent,
children: [
{ path: '', redirectTo: 'new', pathMatch: 'full' },
{ path: 'all', component: CalendarListComponent, data: { title: 'My Calendar' } },
{ path: 'new', component: CalendarEventComponent, data: { title: 'New Calendar Entry' } },
{ path: ':id', component: CalendarEventComponent, data: { title: 'Calendar Entry' } }
]
}];
次に、コンポーネントでこのインポートを実行します。
import { Title } from '@angular/platform-browser';
import { Router, NavigationEnd, ActivatedRoute } from '@angular/router';
import 'rxjs/add/operator/filter';
import 'rxjs/add/operator/map';
import 'rxjs/add/operator/mergeMap';
インポートしたら、両方を注入できます。
@Component({
selector: 'app-root',
templateUrl: `
<div>
Hello world!
</div>
`
})
export class AppComponent {
constructor( private router: Router,
private activatedRoute: ActivatedRoute,
private titleService: Title) {}
}
ページタイトルを静的に更新するには、次のようにsetTitleを呼び出すだけです。
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) => {
let title = 'Default Title Here'
if(event['title']) {
title = event['title'];
}
this.titleService.setTitle(title);
});
}