Angular中CanDeactivate守卫与MatDialog配合不工作。
创始人
2024-10-31 00:30:51
0

可以使用MatDialog的afterClosed方法来处理这个问题。当我们在导航时使用CanDeactivate守卫时,我们需要等待MatDialog关闭时才能进行导航。以下是示例代码:

在需要MatDialog的组件中,添加打开MatDialog的方法:

import { MatDialog } from '@angular/material'; import { MyDialogComponent } from './my-dialog.component';

export class MyComponent implements OnDestroy { dialogRef: MatDialogRef;

constructor(public dialog: MatDialog) {}

openDialog() { this.dialogRef = this.dialog.open(MyDialogComponent);

// 在MatDialog关闭后,我们可以使用afterClosed方法
// 来设置用户是否进行了操作。
this.dialogRef.afterClosed().subscribe(result => {
  console.log(`Dialog result: ${result}`);
});

}

ngOnDestroy() { if (this.dialogRef) { this.dialogRef.close(); } } }

在CanDeactivate守卫中,我们可以订阅afterClosed方法并根据用户是否进行了操作来进行相关的导航逻辑:

import { Injectable } from '@angular/core'; import { CanDeactivate } from '@angular/router'; import { Observable } from 'rxjs'; import { MatDialog } from '@angular/material'; import { MyDialogComponent } from './my-dialog.component';

export interface ComponentCanDeactivate { canDeactivate: () => Observable | Promise | boolean; }

@Injectable() export class CanDeactivateGuard implements CanDeactivate {

constructor(private dialog: MatDialog) { }

canDeactivate(component: ComponentCanDeactivate): Observable | Promise | boolean { const canDeactivate = component.canDeactivate ? component.canDeactivate() : true;

// 如果可以离开当前页面
if (canDeactivate instanceof Observable) {
  return canDeactivate.pipe(
    switchMap(result => {
      if (result) {
        return this.dialog.open(MyDialogComponent).afterClosed();
      }

      return of(false);
    })
  );
} else {
  if (canDeactivate) {
    return this.dialog.open(MyDialogComponent).afterClosed();
  }

  return of(false);
}

} }

在上面的代码中,我们定义了一个CanDeactivate守卫,并使用MatDialog的afterClosed方法来等待用户是否进行了操作。如果用户进行了操作,我们就可以进行导航,否则就不进行导航。这样,就可以在MatDialog中使用CanDeactivate守卫来控制导航行为了。

相关内容

热门资讯

透视好友!wepoker养号规... 透视好友!wepoker养号规律,竞技联盟辅助(透视)详情教程(有挂细节)-哔哩哔哩1、下载好wep...
透视插件!悦扑克脚本,aapo... 透视插件!悦扑克脚本,aapoker怎么选牌(透视)有挂教程(有挂头条)-哔哩哔哩1、aapoker...
据权威媒体报道!wepoker... 据权威媒体报道!wepoker手机插件,新超圣辅助器,技法教程(有挂秘诀)-哔哩哔哩1、完成wepo...
备受关注的!we poker插... 备受关注的!we poker插件,wepoker有透视底牌吗(透视)推荐教程(有挂解密)-哔哩哔哩1...
据统计!竹间茶馆透视码,wep... 据统计!竹间茶馆透视码,wepoker插件辅助,机巧教程(真的有挂)-哔哩哔哩1)竹间茶馆透视码辅助...
透视app!wepoker免费... 透视app!wepoker免费透视,德普之星辅助工具如何打开(透视)解谜教程(真的有挂)-哔哩哔哩德...
记者获悉!789大菠萝辅助,火... 记者获悉!789大菠萝辅助,火神大厅开挂,秘籍教程(真的有挂)-哔哩哔哩一、789大菠萝辅助可以开透...
最新消息!约局吧德州真的有透视... 最新消息!约局吧德州真的有透视挂吗,we-poker是什么软件(透视)推荐教程(有挂神器)-哔哩哔哩...
现场直击!欢聚水鱼智能辅助,人... 现场直击!欢聚水鱼智能辅助,人海大厅反杀,步骤教程(存在有挂)-哔哩哔哩1)欢聚水鱼智能辅助辅助插件...
透视了解!wpk透视工作室,w... 透视了解!wpk透视工作室,wepoker私人局怎么玩(透视)解密教程(有挂攻略)-哔哩哔哩1、操作...