程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了订阅触发两次大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决订阅触发两次?

开发过程中遇到订阅触发两次的问题如何解决?下面主要结合日常开发的经验,给出你关于订阅触发两次的解决方法建议,希望对你解决订阅触发两次有所启发或帮助;

我尝试在两个组件之间进行通信,一个是 dialog.component.ts,另一个是 admin.component.ts,它们之间有一个服务。

所以在我的对话框中,我有一个表单,它通过 ngsubmit 触发了服务

collectsubmitForm(any) {
    var myObj= new Object({form: any,typeOfForm: this.data.titleDialog});
    this.dialogContentservice.getCollectFormContent(myObj);
  }

在我的 dialogservice 我有:

  private dialogFormContent = new Subject<any>();

  dialogFormContentupdate$ = this.dialogFormContent.asObservable();

  constructor() {

  }

  getCollectFormContent(dataAsParams) {
    this.dialogFormContent.next(dataAsParams);
    this.dialogFormContent = new Subject<any>();
  }

在我的 admin.component.ts 中,我有: //Todo revoir 2 调用

 constructor(private dialogservice: DialogservicE) {
    this.collectDataFromDialog();
  }
  collectDataFromDialog() {
    this.subscription = this.dialogservice.dialogFormContentupdate$.subscribe(valueFromFormDialog => {
      if(valueFromFormDialog){
        this.subscriptionValueFromDialog = valueFromFormDialog;
        this.anOtherFunction(this.subscriptionValueFromDialog)
      }
    });
  }

ngOnDestroy() {
    this.subscription.unsubscribe()
  }

不知道为什么订阅会被调用两次

解决方法

早上好:D

大概是这部分代码

  getCollectFormContent(dataAsParams) {
    this.dialogFormContent.next(dataAsParams);
    this.dialogFormContent = new Subject<any>();
  }

我认为您需要像这样删除新的 Subject():

  getCollectFormContent(dataAsParams) {
    this.dialogFormContent.next(dataAsParams);
  }

试试吧:D

,

在对话框中的一个组件和另一个组件之间进行数据绑定的另一个很好的解决方案我已经回答了 here。

大佬总结

以上是大佬教程为你收集整理的订阅触发两次全部内容,希望文章能够帮你解决订阅触发两次所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: