mat-nav-list всегда фокусируется на элементах

#angular #typescript #angular-material #angular7 #routerlinkactive

#angular #typescript #angular-материал #angular7 #routerlinkactive

Вопрос:

У меня есть меню навигации. Когда я открываю его, администраторы кнопок / ссылок (пользователи) всегда ведут себя как элемент активного списка, но это не должно.

меню навигации

Вот мой HTML, он находится в mat-nav-list, * ngf проверяет, должен ли пользователь видеть ссылку.

   <a mat-list-item [routerLink]="['/availability']" (click)="linkFollow.emit()" *ngIf="showAvailabilityButton | async">
    <mat-icon mat-list-icon>event_available</mat-icon>
    <h4 mat-line>Beschikbaarheid</h4>
  </a>
  <a mat-list-item *ngIf="showAvailabilityMenu | async" [matMenuTriggerFor]="availabilityMenu">
      <mat-icon mat-list-icon>event_available</mat-icon>
      <h4 mat-line>Beschikbaarheid</h4>
    </a>
    <mat-menu #availabilityMenu="matMenu" xPosition="after" [overlapTrigger]="false">
      <a mat-menu-item [routerLink]="['/availability']" (click)="linkFollow.emit()" *ngIf="showAvailabilityMenuMine | async">Mijn beschikbaarheid</a>
      <a mat-menu-item [routerLink]="['/manage/timeblocks']" (click)="linkFollow.emit()" *ngIf="showAvailabilityMenuTimeblocks | async">Tijdsblokken</a>
      <a mat-menu-item [routerLink]="['/manage/availability']" (click)="linkFollow.emit()" *ngIf="showAvailabilityMenuPerUser | async">Beschikbaarheid aanpassen</a>
      <a mat-menu-item [routerLink]="['/manage/availability/overview']" (click)="linkFollow.emit()" *ngIf="showAvailabilityMenuOverview | async">Overzicht</a>
    </mat-menu>

  <!-- ABSENCE -->

  <a mat-list-item [routerLink]="['/absence']" (click)="linkFollow.emit()" *ngIf="showAbsenceButton | async">
    <mat-icon mat-list-icon>beach_access</mat-icon>
    <h4 mat-line>Afwezigheid</h4>
  </a>
  <a mat-list-item *ngIf="showAbsenceMenu | async" [matMenuTriggerFor]="absenceMenu">
    <mat-icon mat-list-icon>beach_access</mat-icon>
    <h4 mat-line>Afwezigheid</h4>
  </a>
  <mat-menu #absenceMenu="matMenu" xPosition="after" [overlapTrigger]="false">
    <a mat-menu-item [routerLink]="['/absence']" (click)="linkFollow.emit()" *ngIf="showAbsenceMenuMine | async">Mijn afwezigheid</a>
    <a mat-menu-item [routerLink]="['/manage/absence']" (click)="linkFollow.emit()" *ngIf="showAbsenceMenuOverview | async">Afwezigheid aanpassen</a>
  </mat-menu>

  <!-- PLANNING -->

  <a mat-list-item [routerLink]="['/planning/view']" (click)="linkFollow.emit()" *ngIf="showPlanningButton | async">
    <mat-icon mat-list-icon>grid_on</mat-icon>
    <h4 mat-line>Planning</h4>
  </a>
  <a mat-list-item *ngIf="showPlanningMenu | async" [matMenuTriggerFor]="planningMenu">
    <mat-icon mat-list-icon>grid_on</mat-icon>
    <h4 mat-line>Planning</h4>
  </a>
  <mat-menu #planningMenu="matMenu" xPosition="after" [overlapTrigger]="false">
    <a mat-menu-item [routerLink]="['/planning/view']" (click)="linkFollow.emit()" *ngIf="showPlanningMenuView | async">Planning bekijken</a>
    <a mat-menu-item [routerLink]="['/planning/edit']" (click)="linkFollow.emit()" *ngIf="showPlanningMenuEdit | async">Planning aanpassen</a>
  </mat-menu>


  <a mat-list-item [routerLink]="['/users']" (click)="linkFollow.emit()" *ngIf="showUsersButton | async">
    <mat-icon mat-list-icon>people</mat-icon>
    <h4 mat-line>Gebruikers</h4>
  </a>
  <a mat-list-item [routerLink]="['/hour-registration']" (click)="linkFollow.emit()" *ngIf="showHourRegistrationButton | async">
    <mat-icon mat-list-icon>schedule</mat-icon>
    <h4 mat-line>Uren Registratie</h4>
  </a>
  <a mat-list-item [routerLink]="['/employe-materials']" (click)="linkFollow.emit()" *ngIf="showEmployeeMaterials | async">
    <mat-icon mat-list-icon>pan_tool</mat-icon>
    <h4 mat-line>Werk benodigheden</h4>
  </a>
  <a mat-list-item [routerLink]="['/messages']" (click)="linkFollow.emit()" *ngIf="showMessageButton | async">
    <mat-icon mat-list-icon>message</mat-icon>
    <h4 mat-line>Berichten</h4>
  </a>
  

Я пытался использовать routerLinkActive=»активный элемент списка», но с тем же результатом другие ссылки не получают класс active-list-item.

Итак, как я могу изменить, что ссылка Gebruikers не выбрана по умолчанию, или как я могу заставить routerLinkActive работать?

Ответ №1:

Итак, я немного схитрил и исправил свою проблему с использованием фиктивной ссылки прямо под «mat-nav-list»

   <div class="hidden">
        <a mat-list-item [routerLink]="['/profile']">
            <h4 mat-line></h4>
        </a>
    </div>
  

И немного CSS, чтобы скрыть это. Я не использую display: none или visabilty: false (не уверен, что это правильно), потому что таким образом, фиктивный файл не получает renderend, а для ссылки Gebruikers (пользователи) по-прежнему установлено значение active-list-item.

 .hidden{
  height: 1px;
  opacity: 0;
}
  

Ответ №2:

Одно из решений, которое я нашел, также столкнувшись с этой проблемой, заключается в том, что вы можете удалить CSS по умолчанию для наведения и добавить новый в отдельный класс. Добавить добавьте этот класс к каждому элементу mat-list.

 .mat-nav-list .mat-list-item:hover,
.mat-nav-list .mat-list-item:focus {
  background: transparent;
}

.menu-item:hover {
  background: rgba(0,0,0,.04) !important;
}