2

我有打开材料对话框的组件 A

A组份

  openDialog(): void {
    const dialogRef = this.dialog.open(**component B**, {
      width: '1000px',
    });

然后我使用在该对话框中加载图像并通过按钮上传我使用组件 B 将其上传到服务器。现在,当我上传完图片后,我想从组件 B 中关闭该对话框。

B组份

onUpload() {
  const fd = new FormData(); 
  fd.append('image', this.selectedFile);
  this.service.uploadImage(fd).subscribe(
    (res:any)=>
    {
//how to close dialog here ?

    },

我怎样才能做到这一点 ?

4

1 回答 1

7

对话 | 角材料文档

通过 MatDialog 创建的组件可以注入 MatDialogRef 并使用它来关闭包含它们的对话框。关闭时,可以提供可选的结果值。此结果值作为 afterClosed 承诺的结果转发

export class ComponentB {
  constructor(
    public dialogRef: MatDialogRef<DialogOverviewExampleDialog>
  ) {}

  onUpload(): void {
    // upload stuff

    this.dialogRef.close();
  }
}
于 2019-09-06T12:41:50.483 回答