AngularNgoninit每次路由时都会被调用
创始人
2024-10-28 17:01:15
0

使用RxJS的takeUntil操作符将订阅取消时机与路由导航关联起来,以便在组件销毁前取消未完成的订阅。

示例代码:

import { Component, OnInit, OnDestroy } from '@angular/core'; import { takeUntil } from 'rxjs/operators'; import { Subject } from 'rxjs'; import { Router, NavigationEnd } from '@angular/router';

@Component({ selector: 'app-my-component', templateUrl: './my-component.component.html', styleUrls: ['./my-component.component.css'] }) export class MyComponentComponent implements OnInit, OnDestroy { private ngUnsubscribe = new Subject();

constructor(private router: Router) { }

ngOnInit() { this.router.events .pipe(takeUntil(this.ngUnsubscribe)) .subscribe(event => { if (event instanceof NavigationEnd) { // 在这里编写处理导航结束时要做的事情 } }); }

ngOnDestroy() { this.ngUnsubscribe.next(); this.ngUnsubscribe.complete(); } }

在组件的ngOnInit方法中,使用takeUntil操作符将路由事件与ngUnsubscribe主体关联起来,以便在组件销毁之前取消任何未完成的订阅。在这个例子中,我们只关心NavigationEnd事件。在组件的ngOnDestroy方法中,我们取消与ngUnsubscribe相关的所有订阅。

相关内容

热门资讯

透视练习!德普软件,德普之星透... 透视练习!德普软件,德普之星透视辅助软件(透视)总是真的有透视工具(哔哩哔哩)所有人都在同一条线上,...
透视方案!wepoker怎么开... 透视方案!wepoker怎么开辅助,wepoker游戏的安装教程(透视)本来真的有透视教程(哔哩哔哩...
透视机巧!wepoker有没有... 透视机巧!wepoker有没有机器人,wepoker辅助器有哪些功能(透视)竟然是真的透视器(哔哩哔...
透视方针!德普之星有透视辅助吗... 透视方针!德普之星有透视辅助吗,德普之星有辅助软件吗(透视)果然真的有脚本器(哔哩哔哩)1)德普之星...
透视举措!红龙poker有辅助... 透视举措!红龙poker有辅助吗,pokemomo辅助软件(透视)本来是真的透视方法(哔哩哔哩)1)...
透视阶段!悦扑克脚本,poke... 透视阶段!悦扑克脚本,pokemmo脚本手机版(透视)总是有脚本工具(哔哩哔哩)1、pokemmo脚...
透视步骤!wepoker辅助器... 透视步骤!wepoker辅助器软件下载,购买的wpk辅助在哪里下载(透视)其实存在有挂(哔哩哔哩)1...
透视步骤!聚星ai辅助工具激活... 透视步骤!聚星ai辅助工具激活码,poker辅助器免费安装(透视)一直是真的挂(哔哩哔哩)1、透视步...
透视经验!wpk有辅助器吗,w... 透视经验!wpk有辅助器吗,wepoker免费脚本(透视)总是是真的挂(哔哩哔哩)一、wepoker...
透视绝活儿!wpk辅助是什么,... 透视绝活儿!wpk辅助是什么,wpk透视插件(透视)一直是真的脚本脚本(哔哩哔哩)1)wpk辅助是什...