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";
}
}
如果有人熟悉这种错误,请帮助我。
您在组件级别维护 iconName
和 itemStatis
而不是 在 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>
我正在使用 Mat-card 使用数组和 *ngFor 显示列表,当按下按钮时,它只会更改所选卡片上的图标 (mat-icon),但它会更改所有列表中的按钮。
这里有一个例子:
但是当我按下它时所有的图标都会改变。
这是我的代码:
<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";
}
}
如果有人熟悉这种错误,请帮助我。
您在组件级别维护 iconName
和 itemStatis
而不是 在 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>