本文介绍了Angular 2 Click + ngClass,如何仅应用于 SELF 而不是 ngFor 中的所有元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

在 Angular 1.x 中以下代码可以在我想要单击并翻转 ng-repeat 中的卡片时工作

In Angular 1.xthis following code works as I want to to click and flip a card inside an ng-repeat

<div class="card" ng-repeat="let card of cards">
<div class="flipcard" ng-class="{'flipped':isflipped}" ng-click="isflipped = !isflipped">
</div>
</div>

但是在 Angular 2 中单击时,它会翻转 ngFor 循环中的每个卡片"...如何仅将 ngClass 条件绑定到元素本身?

However in Angular 2when clicked, it flipped every "card" inside the ngFor loop... how do I bind the ngClass condition to the element itself only?

<div class="card" *ngFor="let card of cards">
<div class="flipcard"  [ngClass]="{'flipped': isflipped }" (click)="isflipped = !isflipped;">
</div>
</div>

推荐答案

改成:

<div class="card" *ngFor="let card of cards">
    <div class="flipcard"  [ngClass]="{'flipped': card.isflipped }" (click)="card.isflipped = !card.isflipped;">
    </div>
</div>

这篇关于Angular 2 Click + ngClass,如何仅应用于 SELF 而不是 ngFor 中的所有元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

07-22 13:59