Я новичок в angular Я пытаюсь изменить состояние моей кнопки в навигационной панели, учитывая маршрут навигации, однако, нажимая мою кнопку, я выбираю все остальные кнопки, включая нажатую кнопку.
Здесь у меня есть метод, который я вызываю на кнопке:
private status = false;
selectOnMenu(event) {
const urlBase = this.location.path();
if (urlBase === '/documents/index/my') {
this.status = !this.status;
} else if (urlBase === '/documents/index/sending') {
this.status = !this.status;
} else if (urlBase === '/documents/index/receiving') {
this.status = !this.status;
} else if (urlBase === '/documents/index/received') {
this.status = !this.status;
} else if (urlBase === '/documents/index/finished') {
this.status = !this.status;
} else {
this.status = status;
}
}
и это меню моих кнопок:
<div class="btn-group" role="group" aria-label="...">
<a class=" btn btn-square" (click)="selectOnMenu($event)" [ngClass]="status ? 'active' : ''" routerLink="/documents/index/my">MIS DOCUMENTOS</a>
<a class=" btn btn-square" (click)="selectOnMenu($event)" [ngClass]="status ? 'active' : ''" routerLink="/documents/index/sending">PENDIENTES POR DESPACHAR</a>
<a class=" btn btn-square" (click)="selectOnMenu($event)" [ngClass]="status ? 'active' : ''" routerLink="/documents/index/receiving">PENDIENTES POR RECEPCIONAR</a>
<a class=" btn btn-square" (click)="selectOnMenu($event)" [ngClass]="status ? 'active' : ''" routerLink="/documents/index/received">RECEPCIONADOS</a>
<a class=" btn btn-square" (click)="selectOnMenu($event)" [ngClass]="status ? 'active' : ''" routerLink="/documents/index/finished">FINALIZADOS</a>
</div>
Я пытался изменить свой метод, но он по-прежнему помечает все кнопки при нажатии, что неверно, поскольку должна выделяться только выбранная кнопка.
