Mat-icon:按下按钮时所有图标都会改变

Mat-icon: when pressing a button all the icons change

我正在使用 Mat-card 使用数组和 *ngFor 显示列表,当按下按钮时,它只会更改所选卡片上的图标 (mat-icon),但它会更改所有列表中的按钮。

这里有一个例子:

在按下按钮之前,更改图标的条件为 false

但是当我按下它时所有的图标都会改变。

这是我的代码:

<mat-card  *ngFor="let a of items ;let i = index" class="item-card mat-card">

        <mat-card-header class="card-mat-header" style="margin-top: 10px;">
          <div class="card-mat-header-text"></div>

          <mat-card-title class="card-mat-title">{{a.name}}</mat-card-title>
          <mat-card-subtitle>Price :{{a.price}}</mat-card-subtitle>
        </mat-card-header>
        <div class="img-wrapper">      
            <img class="mat-card-image"  src={{a.image}} alt="Photo of a Shiba Inu">

        </div>
        <mat-card-content>
          <p>
            {{a.desc}}
          </p>
        </mat-card-content>

        <mat-card-actions class="right-button" >
          <button  mat-button class="mat-button mat-button-base" (click)="itemStatus(i)" > 
            <mat-icon>{{iconName}}</mat-icon>{{itemStatis}} {{a.addedToCart}}
          </button>

        </mat-card-actions>
      </mat-card>

还有使用的函数:

  itemStatus(i){

      this.items[i].addedToCart =  !this.items[i].addedToCart
      if(this.items[i].addedToCart)
      {
        this.iconName = "shopping_cart";
        this.itemStatis= "Added";
      }
      else{
        this.iconName = "add_shopping_cart";
        this.itemStatis= "Add To Cart";
      }
    }

如果有人熟悉这种错误,请帮助我。

您在组件级别维护 iconNameitemStatis 而不是 item 级别

检查下面的示例

https://stackblitz.com/edit/angular-ivy-moun8k

在XComponent.ts中将itemStatus改为

itemStatus(i){
  this.items[i].addedToCart =  !this.items[i].addedToCart
}

在 HTML 中将按钮部分更改为

<button  mat-button class="mat-button mat-button-base" (click)="itemStatus(i)" > 
  <mat-icon>{{a.addedToCart ? 'shopping_cart' : 'add_shopping_cart'}}</mat-icon>
    {{a.addedToCart ? 'Added' : 'Add To Cart'}} 
</button>