如何解决异步代码中带有 matDialog 的 canDeactivate
我无法从异步代码中捕获 matDialog 响应。下面是展示我的实现的代码片段。
guard.ts
export class CanDeactivateGuard
implements CanDeactivate<ComponentCanDeactivate> {
constructor(private modalService: MatDialog,private testing: TestingService) {}
canDeactivate(
component: ComponentCanDeactivate
): Observable<boolean> | Promise<boolean> | boolean {
//calling a service to check if user has access to forms
return this.testing.test().toPromise()
.then(res => {
const dialogRef = this.modalService.open(DialogComponent,{
width: '600px',height: '250px'
});
return dialogRef.afterClosed().pipe(
map(result => result === true)
);
})
.catch(() => return true); // user navigate away if does not have permission
}
}
但是此代码无法在对话框中获取用户操作的输入。 我无法找到可能是什么问题以及如何在异步代码中处理 matDialog。我很想知道如何处理这种情况。
注意:这是非常通用的代码示例,而不是实际代码。如果您需要额外的信息来理解场景,请发表评论。
提前致谢。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。