我试图使用RouterLink从一个页面重定向到另一页,但是重定向的链接并未触发ngoninit()方法以及activatedRoute订阅。重定向页面然后冻结,但控制台上没有错误。
所以这是我的HTML
<a [routerLink]="route(value.id)">link</i></a>
那么这是我的component.ts,它返回url
route = (id: number) => this.routeService.view(id);
这是重定向的组件edit.ts
ngOnInit() {
this.route.paramMap.pipe(
takeUntil(this.onDestroy$),
map(params => console.log(params))
).subscribe(x => 'do something')
}
我做了一些黑客,我使用了ngzone。routerLink
指令似乎在角区域外运行。因此,我不使用[routerLink]="route(value.id)"
,而是使用(click)="route(value.id)"
。所以这就是现在的样子
html:
<a (click)="route(value.id)">link</i></a>
组件:
constructor(private ngZone: NgZone){}
route = (id: number) {
const link = this.routeService.view(id);
this.ngZone.run(() => this.router.navigate(link));
}
感谢您的回复..