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守卫来控制导航行为了。

相关内容

热门资讯

黑科技科技(wepoke智能a... 黑科技科技(wepoke智能ai)wepower使用说明书(wepOkE)素来是真的有挂(确实有挂)...
黑科技模拟器(wepoke智能... WePoker透视辅助工具核心要点解析‌,黑科技模拟器(wepoke智能ai)wepoke是机器发牌...
黑科技脚本(wepokeai代... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
黑科技辅助挂(wepoke真的... 黑科技辅助挂(wepoke真的有挂)wepoke 软件(wEPOKE)固有真的有挂(有挂猫腻)-哔哩...
黑科技辅助挂(wepoke黑科... 黑科技辅助挂(wepoke黑科技)wepoke软件透明挂演示(wEpOke)一直真的有挂(真的有挂)...
黑科技app(wepoke真的... 此外,数据分析德州()辅助神器app还具备辅助透视行为开挂功能,通过对客户透明挂的深入研究,你可以了...
黑科技智能ai(wepoke辅... 黑科技智能ai(wepoke辅助插件)wepoke软件透明(WEPOke)先前是有挂(果真有挂)-哔...
黑科技模拟器(wepoke透明... 黑科技模拟器(wepoke透明黑科技)wepoke德州扑克用ai代打(WEPOKE)最初存在有挂(有...
黑科技插件(wepoke辅助插... 黑科技插件(wepoke辅助插件)wepoke软件透明(WEPOke)从来是真的有挂(有挂解惑)-哔...
黑科技美元局(wepoke智能... 黑科技美元局(wepoke智能ai)wepoke辅助真的假的(wepoKE)原先真的有挂(竟然有挂)...