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透视脚本下载,微乐山西小程序破解器,技法教程(详细教程)-哔哩哔哩1、玩家可...
详细透视!wepoker辅助器... 您好,wepoker辅助器是真的吗这款游戏可以开挂的,确实是有挂的,需要了解加去威信【4852750...
必备透视!wepoker有辅助... 必备透视!wepoker有辅助工具吗,微乐自建房脚本免费下载入口,资料教程(有挂讲解)-哔哩哔哩1、...
辅助透视!aapoker怎么拿... 辅助透视!aapoker怎么拿好牌,微乐房间辅助工具在哪下载,要领教程(今日头条)-哔哩哔哩1、每一...
分享透视!德州圈脚本,微乐四川... 分享透视!德州圈脚本,微乐四川亲友圈辅助器,烘培教程(有挂秘诀)-哔哩哔哩1、德州圈脚本辅助器安装包...
解密透视!wpk透视插件,微乐... 解密透视!wpk透视插件,微乐广西小程序脚本,技法教程(有挂总结)-哔哩哔哩wpk透视插件透视方法中...
详情透视!pokemmo辅助工... 详情透视!pokemmo辅助工具,微信小程序微乐辅助器苹果,方式教程(真实有挂)-哔哩哔哩;1、po...
解迷透视!aapoker安装包... 解迷透视!aapoker安装包怎么使用,微信小程序微乐房间怎么辅助,妙计教程(真的有挂)-哔哩哔哩1...
推荐透视!wepoker怎么下... 推荐透视!wepoker怎么下载游戏,微信微乐辅助脚本平台,课程教程(有挂详情)-哔哩哔哩1、游戏颠...
科普透视!模拟器打开hhpok... 科普透视!模拟器打开hhpoker,微乐自建房运势高有什么表现,总结教程(有挂实锤)-哔哩哔哩一、模...