gpt4 book ai didi

angular - 如何从 MatDialog 获取数据?

转载 作者:行者123 更新时间:2023-12-05 08:32:49 24 4
gpt4 key购买 nike

我正在关注 here 中的文档.我可以将数据传递给对话框,但我没有从中获取数据。我在 .afterClose().subscribe() 上得到了未定义的结果。我错过了什么?我猜我需要在对话框的模板中做一些事情,但上面的文档没有提供示例。这是我的代码:

import {Component, Inject, OnInit} from '@angular/core';
import {MatDialog, MatDialogRef, MAT_DIALOG_DATA} from '@angular/material';

import {MySavior} from '../shared/my-savior';
import {Savior} from '../../savior/shared/savior';
import {SaviorDataService} from '../../savior/shared/savior-data.service';

@Component({
selector: 'app-my-room-savior-select-dialog',
template: 'my data name: {{data.name}}'
})
export class MySaviorSelectDialogComponent {
constructor(public dialogRef: MatDialogRef<MySaviorSelectDialogComponent>,
@Inject(MAT_DIALOG_DATA) public data: any) {}

onClose(): void {
this.dialogRef.close();
}
}


@Component({
selector: 'app-my-room-my-savior',
templateUrl: './my-savior.component.html',
styleUrls: ['./my-savior.component.css']
})
export class MySaviorComponent implements OnInit {

saviors: Savior[] = [];
mySaviors: MySavior[] = [];

constructor(private saviorDataServ: SaviorDataService, public dialog: MatDialog) {}

ngOnInit() {
...
}

openSelectDialog(): void {
const dialogRef = this.dialog.open(MySaviorSelectDialogComponent, {data: {name: 'test'}});
dialogRef.afterClosed().subscribe(result => {
console.log('result ' + result); //i got result undefined
});
}

}

最佳答案

在我注意到我们可以在 MatDialogRef.close() 上传递数据后,我明白了。

onClose(): void {
this.dialogRef.close('pass data here');
}

文档只提供了 onNoClick() 函数,顺便说一句不需要传递任何数据。另一方面,我认为 onOkClick() 应该或多或少类似于上面的 onClose() 。我不知道他们为什么不将其包含在文档中。

关于angular - 如何从 MatDialog 获取数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47234823/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com