Znalazłem ciekawy problem, którego nie mogę się obejść.
Mam cykl następujących urządzeń *ngFor z wydarzeniem kliknięcia.
<label class="input-group" *ngFor="let status of statuses; trackBy: id"
(click)="filterByCategory(status.name)">{{ status.name }}
<span class="chip chip-icon" [attr.data-chip-state]="status.name">
{{ partners | counter: status.name }}</span>
<input type="checkbox" />
<span class="checkmark"></span>
</label>
zdarzenie kliknięcia fn filterByCategory () - jest to prosty proces, który jest odpowiedzialny za dodawanie lub usuwanie wierszy z tablicy, a następnie filtrować tablicę obiektów.
filterByCategory(category, event: Event) {
let verify = this.filterArr.includes(category);
if (!verify) {
this.filterArr.push(category)
} else {
let indexOfCategory = this.filterArr.indexOf(category);
this.filterArr.splice(indexOfCategory, 1);
}
this.filteredPartners = this.partners.filter(partner => {
return this.filterArr.includes(partner.partner_status.name);
})
}
Gdy zdarzenie uruchamia się, jest wykonywana dwukrotnie, a operator if najpierw dodaje się wiersz, a następnie usuwa je.
Czy ma ktoś sposób na rozwiązanie tego problemu?
Dziękuję!