javascript - 基于 routerLinkActive 的 Angular 高亮

标签 javascript css angular

我想根据路由切换 routerLinkActive 的突出显示, 我有一个仪表板组件,仪表板菜单项和标签菜单项都引用同一个组件,我想根据路线向 li 元素添加类 对于仪表板,路线将是

http://localhost:4300/dashboard

对于标签,路线将是

http://localhost:4300/dashboard/5d1bb53877ed8702d8a01940

菜单项代码

 <ul class="sidebar-nav">
                <li [ngClass]="{ active: rlal && rlal.isActive == false }">
                  <a [routerLink]="['/dashboard']" (click)="loadSnippet(null)">
                    <mat-icon>dashboard</mat-icon>
                    <span>Dashboard</span>
                  </a>
                </li>

     <h3 *ngIf="labelList && labelList.length!=0">Labels</h3>
              <ul class="sidebar-nav">
                <li *ngFor="let label of labelList" [ngClass]="rlal && rlal.isActive ? 'active' : ''"
                  routerLinkActive="rlal.isActive">
                  <a [routerLink]="['/dashboard', label._id]" routerLinkActive #rlal="routerLinkActive"
                    (click)="loadSnippet(label)">
                    <mat-icon>label</mat-icon>
                    <span>{{ label.label_name }} </span>
                  </a>
                </li>
              </ul>

路线:

 {
    path: "dashboard",
    component: DashboardComponent,
    canActivate: [LoggedInGuard]
  },
  {
    path: "dashboard/:labelId",
    component: DashboardComponent,
    canActivate: [LoggedInGuard]
  }

对于单个标签项,突出显示效果很好,但对于仪表板,li 没有突出显示

enter image description here

最佳答案

如果您希望仪表板链接仅在没有路由参数时处于事件状态,则需要添加 routerLinkActive[routerLinkActiveOptions]="{exact: true}"到你的仪表板 li 节点。

此外,您不需要通过 ngClass 设置 active 类,因为 routerLinkActive 会为您完成。

<li routerLinkActive="active" [routerLinkActiveOptions]="{exact: true}">
  <a routerLink="/dashboard" (click)="loadSnippet(null)">
    <mat-icon>dashboard</mat-icon>
    <span>Dashboard</span>
  </a>
</li>

 ...

<li routerLinkActive="active" *ngFor="let label of labelList">
  <a [routerLink]="['/dashboard', label._id]" (click)="loadSnippet(label)">
    <mat-icon>label</mat-icon>
    <span>{{ label.label_name }}</span>
  </a>
</li>

关于javascript - 基于 routerLinkActive 的 Angular 高亮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56922414/

相关文章:

javascript - AngularJS 和 Firebase 教程 : 'TypeError: undefined is not a function;' issue

javascript - 在 ThreeJS 中预加载纹理和图像?

php - 可滚动表格上方的固定标题

html - col-md-# 组件的居中内容

angular2 Material 设计 - react 形式 - md-select 不填充默认值

angular - SEO 检查无法识别 H1 和 H2 标题。 Angular

javascript - 使用 Cypress 在 SVG 上测试 onclick 事件

javascript - 如何使 PIXI 渲染器适应浏览器的宽度和高度?

html - CSS - 在 Safari 上指定字体

html - Angular 2 - 单击以显示和隐藏