Angular 8 MatDialog 等待结果继续
创始人
2024-10-17 14:30:34
0

要在Angular 8中使用MatDialog等待结果并继续执行代码,可以使用Promise和async/await方法。以下是一个示例解决方案:

  1. 在你的组件中,创建一个方法来打开MatDialog并等待结果:
import { MatDialog } from '@angular/material/dialog';

export class YourComponent {
  constructor(private dialog: MatDialog) { }

  openDialog(): Promise {
    return new Promise((resolve, reject) => {
      const dialogRef = this.dialog.open(YourDialogComponent);

      dialogRef.afterClosed().subscribe(result => {
        if (result) {
          resolve(result);
        } else {
          reject();
        }
      });
    });
  }
}
  1. 在组件中调用这个方法并使用async/await方法等待结果:
async yourMethod() {
  try {
    const result = await this.openDialog();
    // 在这里使用结果进行进一步的操作
  } catch (error) {
    // 处理错误
  }
}
  1. 在YourDialogComponent中,当用户完成对话框上的操作时,使用MatDialogRef关闭对话框并传递结果:
import { MatDialogRef } from '@angular/material/dialog';

export class YourDialogComponent {
  constructor(private dialogRef: MatDialogRef) { }

  onConfirm() {
    // 执行一些操作,然后关闭对话框并传递结果
    this.dialogRef.close('确认');
  }

  onCancel() {
    // 执行一些操作,然后关闭对话框并传递结果
    this.dialogRef.close('取消');
  }
}

通过使用Promise和async/await方法,你可以在等待MatDialog结果时暂停执行代码,并在结果可用时继续执行。

相关内容

热门资讯

两分钟辅助!开心泉州小程序开挂... 两分钟辅助!开心泉州小程序开挂有什么技巧,原来真的是有辅助插件(有挂教学)开心泉州小程序开挂有什么技...
七分钟辅助!奇迹脚本辅助,真是... 七分钟辅助!奇迹脚本辅助,真是有辅助软件(确实有挂)1、超多福利:超高返利,海量正版游戏,奇迹脚本辅...
一分钟辅助!天天贵阳智能辅助器... 一分钟辅助!天天贵阳智能辅助器,原来是有辅助脚本(真的有挂)亲,关键说明,天天贵阳智能辅助器透视脚本...
3分钟辅助!一起宁德钓蟹黑科技... 3分钟辅助!一起宁德钓蟹黑科技辅助软件推荐,其实真的有辅助挂(有挂存在)1、玩家可以在一起宁德钓蟹黑...
第二分钟辅助!大菠萝789辅助... 第二分钟辅助!大菠萝789辅助器下载,原来存在有辅助挂(存在有挂)运大菠萝789辅助器下载辅助工具,...
3分钟辅助!科乐填坑辅助,原来... 3分钟辅助!科乐填坑辅助,原来真的是有辅助器(有挂方略)1、下载好科乐填坑辅助透视辅助下载之后点击打...
3分钟辅助!潮友会透视辅助教程... 3分钟辅助!潮友会透视辅助教程,果然存在有辅助器(有挂辅助)亲,关键说明,潮友会透视辅助教程透视脚本...
4分钟辅助!福建兄弟十三冰修改... 4分钟辅助!福建兄弟十三冰修改器,本来真的是有辅助app(有挂讲解)1、游戏颠覆性的策略玩法,独创攻...
第二分钟辅助!wepoker插... 第二分钟辅助!wepoker插件程序,真是是真的有辅助技巧(有挂细节)1、不需要AI权限,帮助你快速...
1分钟辅助!悠悠互娱辅助,真是... 1分钟辅助!悠悠互娱辅助,真是是有辅助神器(有挂解密)悠悠互娱辅助透视方法中分为三种模型:悠悠互娱辅...