angular路由高亮--長明燈RouterLinkActive

路由高亮是什麼?有什麼好處?

當你在作一個後臺管理系統,左邊是一排路由導航,點擊能夠進入不一樣的頁面,那麼這個路由所在dom元素會添加上樣式表示當前是位置。
可是一刷新你會發現,這個樣式沒了...
怎麼辦?bash

採用路由高亮:當路由被激活時容許你添加一個class在你添加路由的dom元素上,只有url變化時纔會移除此樣式。dom

當前路由被激活或者當前路由處於激活狀態表示頁面的url中路由和當前dom標籤裏的路由想匹配。ui

// 用法概覽
@Directive({
    selector: '[routerLinkActive]',
    exportAs: 'routerLinkActive'
})
class RouterLinkActive implements OnChanges, OnDestroy, AfterContentInit {
  constructor(router: Router, element: ElementRef, renderer: Renderer2, cdr: ChangeDetectorRef)
  links: QueryList<RouterLink>
  linksWithHrefs: QueryList<RouterLinkWithHref>
  get isActive: boolean
  routerLinkActiveOptions: {...}
  set routerLinkActive: string[] | string
  ngAfterContentInit(): void
  ngOnChanges(changes: SimpleChanges): void
  ngOnDestroy(): void
}
複製代碼

示例

.red{
    color: red;
}
複製代碼
<a routerLink="/user/login" routerLinkActive="red">login</a>
複製代碼

當url是user或者/user/login的時候,a標籤將會被加上classred。當url變化爲別的時,class將會被移除。url

如何添加兩個class?

<a routerLink="/user/login" routerLinkActive="class1 class2">login</a>
複製代碼

routerLinkActive的兩種寫法

<a routerLink="/user/login" routerLinkActive="class1 class2">login</a>
<a routerLink="/user/login" [routerLinkActive]="['class1', 'class2']">login</a>
複製代碼

也能夠給routerLinkActive進行配置參數

傳遞exact: true表示路由徹底匹配時才高亮,如spa

<a routerLink="/user/login" routerLinkActive="red" [routerLinkActiveOptions]="{exact: true}">login</a>
複製代碼

你還能夠使用isActive檢查當前是否路由處於激活狀態

<a routerLink="/user/login" routerLinkActive #rla="routerLinkActive">
  login {{ rla.isActive ? '激活' : '未激活'}}
</a>
複製代碼

若是當前路由處於激活狀態,則會顯示:code

login 激活
複製代碼

非激活狀態router

login 未激活
複製代碼

上述的 rla 爲routerLinkActive縮寫,它能夠隨便定義。element

重點來了:子菜單被選中,父級菜單也想高亮顯示怎麼辦?

你能夠在使用routerLink元素的父元素上使用RouterLinkActive指令路由

<div routerLinkActive="red" [routerLinkActiveOptions]="{exact: true}">
  <a routerLink="/user/login">login</a>
  <a routerLink="/user/reset">reset</a>
</div>
複製代碼
  • 只要給a標籤的父元素div添加上routerLinkActiverouterLinkActiveOptions, 當路由是/user/login/user/reset時其父元素div會被添加上red樣式。
  • 這裏須要注意的是routerLinkActiveOptions指徹底匹配,否則會出現url爲/user時父元素也會被添加了red樣式。

若是routerLink的值是變量的話

routerLink={{temp}}
複製代碼

temp就是你的變量名get

相關文章
相關標籤/搜索