0

我的 Angular 应用程序创建了一个模式对话框,允许用户输入和更改一些属性。当用户尝试取消模态(单击 X,或单击模态外部)时,请求警告用户模型中有未保存的更改。

const modal = this.modalService.create({
  nzTitle: title,
  nzContent: MyModalComponent,
  nzComponentParams: {
      // component parameters
  },
  nzFooter: null,
  nzOnCancel: (result) => {
    if (result changed) {
      return;
    } else {
      return new Promise((resolve, reject) => {
         this.modalService.confirm({
           nzTitle: `If you leave, your unsaved changes will be lost. Do you want to leave?`,
           nzOkText: 'Yes',
           nzOkType: 'danger',
           nzOnOk: () => resolve(true),
           nzCancelText: 'No',
           nzOnCancel: () => resolve(false),
         });
       }).catch(() => console.log('cancel'))
    }
  }
});

在上面的代码中,“结果”没有反映模态的变化,因此它不起作用。

实现它的最佳方法是什么?

4

2 回答 2

0

当为 Component 时,nzOnCancel可以接受 Component 实例作为函数参数nzContent,该函数返回 a promise,当执行完成或 promise 结束时自动关闭(返回false防止关闭)。

您可以在此处查看在线示例:

https://stackblitz.com/edit/ng-zorro-antd-start-rd9gqh

于 2019-05-18T06:08:03.690 回答
0

如果有任何未保存的更改,您可以添加一个确认框警报。像bootbox这样的东西确认。

Bootbox 使用 stackoverflow 链接

确保 bootbox 的 z-index 大于 modal

于 2019-04-29T13:58:32.363 回答