要向Angular Material对话框发送数据,您可以使用MatDialog的open方法,同时传递一个配置对象。这个配置对象可以包含要传递给对话框的任何数据。以下是一个包含代码示例的解决方法:
在组件中打开对话框:
import { Component, Inject } from '@angular/core';
import { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
@Component({
  selector: 'app-my-component',
  templateUrl: './my-component.component.html',
  styleUrls: ['./my-component.component.css']
})
export class MyComponent {
  constructor(public dialog: MatDialog) {}
  openDialog(): void {
    const dialogRef = this.dialog.open(DialogComponent, {
      width: '250px',
      data: { name: 'John', age: 30 } // 传递的数据
    });
    dialogRef.afterClosed().subscribe(result => {
      console.log('The dialog was closed');
      console.log('Received data:', result); // 对话框返回的数据
    });
  }
}
在对话框组件中接收数据:
import { Component, Inject } from '@angular/core';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
@Component({
  selector: 'app-dialog-component',
  templateUrl: './dialog-component.component.html',
  styleUrls: ['./dialog-component.component.css']
})
export class DialogComponent {
  constructor(
    public dialogRef: MatDialogRef,
    @Inject(MAT_DIALOG_DATA) public data: any
  ) {}
  onNoClick(): void {
    this.dialogRef.close();
  }
}
 在对话框组件的HTML模板中显示数据:
Data passed to dialog
  Name: {{ data.name }}
  Age: {{ data.age }}
  
这样,当您调用openDialog方法时,会打开一个对话框,并将数据{ name: 'John', age: 30 }传递给对话框。对话框组件中的模板将显示传递的数据。当用户关闭对话框时,您可以在afterClosed订阅中访问返回的数据。