Angular中*ngFor和MatDialog的问题
创始人
2024-10-31 00:01:09
0

问题1:在Angular中使用*ngFor遍历数据时,如何在MatDialog中传递当前循环的对象?

解决方法:

  1. 在循环中为每个对象添加一个点击事件,将当前对象传递给MatDialog。
{{ item.name }}
  1. 在组件中定义一个openDialog方法,并将当前对象传递给MatDialog。
import { Component, Inject } from '@angular/core';
import { MatDialog, MAT_DIALOG_DATA } from '@angular/material/dialog';

@Component({
  ...
})
export class YourComponent {

  constructor(public dialog: MatDialog) {}

  openDialog(item: any): void {
    const dialogRef = this.dialog.open(YourDialogComponent, {
      data: item
    });

    dialogRef.afterClosed().subscribe(result => {
      console.log('The dialog was closed');
    });
  }
}
  1. 在对话框组件中通过MAT_DIALOG_DATA注入当前对象。
import { Component, Inject } from '@angular/core';
import { MAT_DIALOG_DATA } from '@angular/material/dialog';

@Component({
  ...
})
export class YourDialogComponent {

  constructor(@Inject(MAT_DIALOG_DATA) public data: any) {}

}

问题2:在MatDialog中如何获取到循环中每个对象的索引值?

解决方法:

  1. 在循环中使用index来获取当前对象的索引值。
{{ item.name }}
  1. 在openDialog方法中将索引值传递给MatDialog。
openDialog(item: any, index: number): void {
  const dialogRef = this.dialog.open(YourDialogComponent, {
    data: { item, index }
  });

  dialogRef.afterClosed().subscribe(result => {
    console.log('The dialog was closed');
  });
}
  1. 在对话框组件中通过MAT_DIALOG_DATA注入包含对象和索引的数据。
import { Component, Inject } from '@angular/core';
import { MAT_DIALOG_DATA } from '@angular/material/dialog';

@Component({
  ...
})
export class YourDialogComponent {

  constructor(@Inject(MAT_DIALOG_DATA) public data: any) {
    console.log(data.item); // 当前对象
    console.log(data.index); // 当前索引值
  }

}

相关内容

热门资讯

黑科技辅助挂(德州免费)wPk... 德州新手教程相关信息汇总(需添加指定威信136704302获取下载链接);黑科技辅助挂(德州免费)w...
黑科技脚本(Wepoke总结)... 黑科技脚本(Wepoke总结)轰趴十三水原本是真的有挂!太坑了果然真的是有挂(2023已更新)(哔哩...
黑科技攻略(微扑克模拟器)wp... 黑科技攻略(微扑克模拟器)wpk游戏原先是有挂!太嚣张了确实存在有挂(2025已更新)(哔哩哔哩);...
黑科技有挂(哈糖大菠萝洗牌)w... 黑科技有挂(哈糖大菠萝洗牌)wPk好像存在有挂!太嚣张了一直有挂(2026已更新)(哔哩哔哩);实战...
黑科技脚本(微扑克ai)Wep... 黑科技脚本(微扑克ai)WepokE确实存在有挂!太嚣张了本然真的是有挂(2020已更新)(哔哩哔哩...
黑科技私人局(aapoker辅... 黑科技私人局(aapoker辅助)AAPoKER真是是有挂!太嚣张了原来是有挂(2025已更新)(哔...
黑科技苹果版(Wepoke助手... 黑科技苹果版(Wepoke助手)wPK原生存在有挂!太实锤了竟然存在有挂(2024已更新)(哔哩哔哩...
黑科技代打(德扑之星模拟器)a... 黑科技代打(德扑之星模拟器)aapokEr固有真的是有挂!太夸张了一直是有挂(2025已更新)(哔哩...
辅助黑科技(aapoker教程... 辅助黑科技(aapoker教程)epoker先前是真的有挂!太夸张了起初真的有挂(2022已更新)(...
黑科技存在(微扑克ai)Wep... 黑科技存在(微扑克ai)WepokE确实存在有挂!太嚣张了总是真的是有挂(2023已更新)(哔哩哔哩...