Angular指令应该在导航后不应重新运行
创始人
2024-10-30 23:00:36
0

要解决这个问题,你可以使用 ngOnDestroy() 生命周期钩子,用它来取消参考 Angular 指令的订阅。

简单的方式是创建一个集中的订阅器,以确保 Angular 管理它们:

@Injectable({ providedIn: 'root' })
export class SubscriptionManagerService implements OnDestroy {
  private subs: Subscription[] = [];

  add(...subs: Subscription[]) {
    this.subs.push(...subs);
  }

  ngOnDestroy() {
    this.subs.forEach(sub => sub.unsubscribe());
  }
}

在应用的根模块的 providers 数组中将它添加进去。现在,你的 Angular 指令可以注入 SubscriptionManagerService,然后调用 add 方法来订阅所有的源。

export class MyDirective implements OnInit, OnDestroy {
  private subs = new Subscription();

  constructor(private subscriptionManager: SubscriptionManagerService) {}

  ngOnInit() {
    this.subs.add(
      // your RxJS subscriptions here
    );
  }

  ngOnDestroy() {
    this.subs.unsubscribe();
  }
}

最后,确保你只使用你的集中的订阅器来订阅与 Angular 指令相关的所有订阅。这样,当导航发生时,所有的订阅将被自动取消,而 Angular 指令也不会重复运行。

相关内容

热门资讯

辅助透视!菠萝德普辅助器免费版... 辅助透视!菠萝德普辅助器免费版在哪里,拱趴大菠萝万能挂(一贯真的是有挂);1、每一步都需要思考,不同...
aapoker俱乐部!aapo... 自定义aapoker俱乐部系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,...
透视了解!德州局透视脚本,po... 透视了解!德州局透视脚本,pokemmo内置修改器(真是是真的有挂);1、pokemmo内置修改器a...
aapoker有猫腻!德州aa... aapoker有猫腻!德州aapoker俱乐部外挂,(aapOker)总是是有挂,详细教程(有挂辅助...
透视教学!pokerworld... 透视教学!pokerworld修改器,哈糖大菠萝有挂吗5个常用方法(竟然存在有挂)运哈糖大菠萝有挂吗...
aapoker辅助工具!aap... aapoker辅助工具!aapoker安卓版辅助,(AAPOKeR)本来有挂,详细教程(有挂了解)1...
透视好友!pokemmo辅助器... 透视好友!pokemmo辅助器手机版下载,pokemmo脚本辅助器(确实真的是有挂)1)pokemm...
aapoker辅助工具存在!a... 1、aapoker辅助工具存在!aapoker有网页版吗,(aApoker)一直有挂,详细教程(有挂...
透视黑科技!pokemmo辅助... 透视黑科技!pokemmo辅助官网,约局吧游戏挂(都是有挂)1、金币登录送、破产送、升级送、活动送。...
aapoker透明挂!aapo... aapoker透明挂!aapoker辅助工具,(AAPoKER)一贯真的有挂,详细教程(有挂黑科技)...