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); // 当前索引值
  }

}

相关内容

热门资讯

透视规律!wepoker有透视... 透视规律!wepoker有透视功能吗(透视)代打辅助(切实有挂);1、在wepoker有透视功能吗a...
透视软件!德普之星透视辅助软件... 透视软件!德普之星透视辅助软件激活码(透视)免费透视(都是存在有挂)1、完成德普之星透视辅助软件激活...
透视透视挂!wepoker透视... 透视透视挂!wepoker透视版下载(透视)免费透视脚本(果然真的有挂);1、上手简单,内置详细流程...
透视了解!wepoker有辅助... 透视了解!wepoker有辅助功能吗(透视)有有挂规律(本来有挂)在进入wepoker有辅助功能吗辅...
透视软件!德普之星透视辅助软件... 透视软件!德普之星透视辅助软件(透视)私人局辅助免费(总是是有挂);该软件可以轻松地帮助玩家将德普之...
透视实锤!WePOker有没有... 透视实锤!WePOker有没有透视方法(透视)可以破解游戏(一贯存在有挂);1、首先打开WePOke...
透视好牌!德普之星怎么设置埋牌... 透视好牌!德普之星怎么设置埋牌(透视)透视(真是有挂)德普之星怎么设置埋牌软件透明挂微扑克wpk插件...
透视规律!wepoker有脚本... 透视规律!wepoker有脚本吗(透视)插件辅助(本来是真的有挂)1、超多福利:超高返利,海量正版游...
透视计算!德普之星有透视辅助吗... 透视计算!德普之星有透视辅助吗(透视)辅助器(确实是真的有挂)1、这是跨平台的德普之星有透视辅助吗黑...
透视插件!德普之星辅助器(透视... 透视插件!德普之星辅助器(透视)透视软件免费入口官网(一贯是有挂);1)德普之星辅助器辅助挂:进一步...