I have a table that shows me a list of item. I want to be able to add a class on the selected item and remove it when I select another one.
Here's my template:
<div >
<div >
<h1>My Shopping List</h1>
<h3 >Add all the ingredients you need</h3>
<app-shopping-edit></app-shopping-edit>
<table>
<tr>
<th>Ingredient</th>
<th>Amount</th>
</tr>
<tr
*ngFor="let ingredient of ingredients; let i = index"
(click)="onEditItem(i)"
>
<td>{{ ingredient.name }}</td>
<td>{{ ingredient.amount }}</td>
</tr>
</table>
</div>
</div>
Here's my ts code:
onEditItem(index: number) {
this.shoppingListService.startedEditing.next(index);
this.addStyleOfSelection(event);
}
addStyleOfSelection(event: any) {
let selection = event.target;
let trSelected = selection.parentNode;
trSelected.classList.toggle('selected');
}
Also "event" is deprecated, but I can't figure out what to use instead.
CodePudding user response:
you can do something like that
<div *ngFor="let item of items" [class.is-selected]="item === selectedItem" (click)="selectedItem = item">{{ item.name }}</div>
CodePudding user response:
you can try another way also, *.html
<div
*ngFor="let item of items; let idx = index"
[ngClass]="{ selected: activeIdx == idx }"
(click)="handleActiveRow(idx)"
>
{{ item.name }}
</div>
and also *.ts file looks
public activeIdx: number | null = null;
public items: Array<any> = [{ name: 'hitee' }, { name: 'krish' }];
public handleActiveRow(event: any) {
this.activeIdx = event;
}
and also *.css looks like,
.selected {
background-color: blueviolet;
}