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相关的所有订阅。

相关内容

热门资讯

热点推荐!!西元红河脚本(透视... 热点推荐!!西元红河脚本(透视)陕麻圈脚本辅助(详细开挂外开挂教程)1、玩家可以在陕麻圈脚本辅助软件...
玩家必看!新鸿狐辅助软件是真的... 玩家必看!新鸿狐辅助软件是真的吗(透视)微信卡农辅助(详细开挂外开挂教程)暗藏猫腻,小编详细说明新鸿...
玩家科普!新玉海楼茶苑挂(透视... 玩家科普!新玉海楼茶苑挂(透视)海贝之城有辅助吗(详细开挂外开挂教程)1、很好的工具软件,可以解锁游...
详细说明!哈糖大菠萝辅助(透视... 详细说明!哈糖大菠萝辅助(透视)福建天天开心辅助(详细开挂外开挂教程)福建天天开心辅助辅助器中分为三...
一分钟了解!!浙江宝宝游戏万能... 一分钟了解!!浙江宝宝游戏万能辅助器(透视)决战卡五星辅助器(详细开挂外开挂教程)1、浙江宝宝游戏万...
技术分享!老友广西玩有破解视频... 技术分享!老友广西玩有破解视频(透视)创思维激k辅助器视频(详细开挂外开挂教程)1、老友广西玩有破解...
专业讨论!!微信小程序中至上饶... 专业讨论!!微信小程序中至上饶麻将有挂(透视)葫芦娃辅助修改器(详细开挂外开挂教程);小薇(透视辅助...
一分钟揭秘!!新二号辅助软件多... 一分钟揭秘!!新二号辅助软件多少钱(透视)新老夫子较二八年(详细开挂外开挂教程)1、新二号辅助软件多...
揭秘攻略!雀神智能插件安装价格... 揭秘攻略!雀神智能插件安装价格(透视)指尖四川辅助脚本视频(详细开挂外开挂教程);1)雀神智能插件安...
一分钟揭秘!!天酷大厅辅助(透... 一分钟揭秘!!天酷大厅辅助(透视)新祥心有挂吗(详细开挂外开挂教程);1.天酷大厅辅助 ai辅助创建...