在Angular中,可以使用CanDeactivate守卫来防止用户离开当前路由。但是当使用材料对话框时,守卫似乎不起作用,不能阻止用户离开当前路由。这是因为对话框会在路由之外呈现,而守卫只能检查当前路由。
解决这个问题的一个简单方法是在对话框关闭时手动导航到目标路由。可以在关闭对话框时调用Router.navigate方法来实现。
下面是一个示例代码:
import { Component, OnInit } from '@angular/core'; import { Router } from '@angular/router'; import { MatDialog } from '@angular/material/dialog';
@Component({
selector: 'app-example',
template: ,
})
export class ExampleComponent implements OnInit {
constructor(private router: Router, private dialog: MatDialog) {}
ngOnInit() {}
openDialog() { const dialogRef = this.dialog.open(DialogComponent);
dialogRef.afterClosed().subscribe((result) => {
if (result) {
this.router.navigate(['/target-route']);
}
});
} }
在这个示例中,当用户点击Open Dialog按钮时,打开一个对话框。当对话框关闭时,如果用户点击确认按钮,就手动导航到目标路由/target-route。