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、超多福...
今天上午!约局吧作必弊脚本(透... 今天上午!约局吧作必弊脚本(透视)九酷众娱辅助(果然有辅助平台)-哔哩哔哩1、进入到约局吧作必弊是否...
有玩家发现!wepoker免费... 有玩家发现!wepoker免费脚本咨询(透视)wepoker透视脚本下载(确实真的是有辅助软件)-哔...
透视最新!wepoker辅助透... 透视最新!wepoker辅助透视(透视)广西老友玩友破解吗(总是真的是有辅助软件)-哔哩哔哩1、游戏...
透视苹果版!wepoker私人... 透视苹果版!wepoker私人局有透视吗(透视)四川游戏家园辅助软件(确实真的有辅助修改器)-哔哩哔...
透视软件!wepoker好友局... 透视软件!wepoker好友局透视(透视)福建13水有挂吗(真是存在有辅助安装)-哔哩哔哩1、福建1...
一直以来!aapoker ai... 一直以来!aapoker ai插件(透视)潮友会鱼虾蟹脚本辅助器(都是是有辅助插件)-哔哩哔哩1、用...
透视安卓版!德普之星app安卓... 透视安卓版!德普之星app安卓版破解版(透视)花花生活圈怎么开挂(果然是真的辅助平台)-哔哩哔哩1、...
透视挂透视!哈糖大菠萝有挂吗5... 透视挂透视!哈糖大菠萝有挂吗5个常用方法(透视)福建大玩家万能辅助器(竟然是有辅助修改器)-哔哩哔哩...
有玩家发现!wepoker轻量... 有玩家发现!wepoker轻量版有透视吗(透视)杭州都莱辅助软件(确实真的有辅助修改器)-哔哩哔哩1...