0

我正在尝试使用 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')

}

4

1 回答 1

1

我做了一点修改,我使用了 NgZone。routerLink指令似乎在 Angular 区域之外运行。所以[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));
}

感谢回复..

于 2019-03-21T02:51:14.170 回答