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)先前是有挂(详细透视可靠教程);1.微扑克辅助软件 ai...
透视好友房(wepoke是真的... 透视好友房(wepoke是真的有挂)微扑克wpk透视辅助(详细辅助技巧教程)素来存在有挂;wpk透视...
透视计算(德扑起手牌胜率图)a... 透视计算(德扑起手牌胜率图)aapoker有什么规律吗(详细辅助曝光教程)其实存在有挂1、很好的工具...
德扑ai智能!德扑之星电脑版,... 1、德扑ai智能!德扑之星电脑版,(德扑ai)果然是有挂(详细透视普及教程)。2、德扑ai智能透视辅...
透视系统(德州之星辅助)微扑克... 自定义系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用辅助器,不管你是想分享给你好...
德州ai人工智能!wopoke... 德州ai人工智能!wopoker有没有外挂,(wePokE)从前是真的有挂(详细透视透牌教程);一、...
透视工具(wpk透明挂)德州w... 透视工具(wpk透明挂)德州wpk德州有挂吗(详细辅助新2025版)竟然有挂您好,,确实是有挂的,很...
智星德州菠萝偷偷看牌功能!we... WePoker透视辅助工具核心要点解析‌,智星德州菠萝偷偷看牌功能!wepoke德扑之星,(德州aa...
透视软件(wpk透视辅助)红龙... 透视软件(wpk透视辅助)红龙扑克是正规的吗(详细辅助可靠教程)果然是真的有挂;人气非常高,ai更新...
aapoker外挂!wpk线上... aapoker外挂新手教程相关信息汇总(需添加指定Q群1067239143获取下载链接);aapok...