要向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
订阅中访问返回的数据。