Angular實(shí)現(xiàn)二級(jí)導(dǎo)航欄
本文實(shí)例為大家分享了Angular實(shí)現(xiàn)二級(jí)導(dǎo)航欄的具體代碼,供大家參考,具體內(nèi)容如下
1、將菜單放入數(shù)據(jù)庫(kù):
模擬放到該路徑下:
src/assets/json/header.json
{ ? ? "siteName": "PGG娛樂(lè)健身中心", ? ? "menu":[ ? ? ? { ? ? ? ? "id":"1", ? ? ? ? "menuName":"首頁(yè)", ? ? ? ? "menuChildren": [{}], ? ? ? ? "showSubMenu": false ? ? ? }, ? ? ? { ? ? ? ? "id":"2", ? ? ? ? "menuName":"健身中心", ? ? ? ? "menuChildren": [ ? ? ? ? ? { ? ? ? ? ? ? "itemId": "1", ? ? ? ? ? ? "menuChidrenItem": "居室器械健身" ? ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "2", ? ? ? ? ? ? "menuChidrenItem": "野外運(yùn)動(dòng)" ? ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "3", ? ? ? ? ? ? "menuChidrenItem": "健身小知識(shí)" ? ? ? ? ? } ? ? ? ? ], ? ? ? ? "showSubMenu": false ? ? ? }, ? ? ? { ? ? ? ? "id":"3", ? ? ? ? "menuName":"休閑娛樂(lè)", ? ? ? ? "menuChildren": [ ? ? ? ? ? { ? ? ? ? ? ? "itemId": "1", ? ? ? ? ? ? "menuChidrenItem": "養(yǎng)生釣魚(yú)" ? ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "2", ? ? ? ? ? ? "menuChidrenItem": "野炊燒烤" ? ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "3", ? ? ? ? ? ? "menuChidrenItem": "真人野戰(zhàn)" ? ? ? ? ? } ? ? ? ? ], ? ? ? ? "showSubMenu": false ? ? ? }, ? ? ? { ? ? ? ? "id":"4", ? ? ? ? "menuName":"訂單中心", ? ? ? ? "menuChildren": [ ? ? ? ? ? { ? ? ? ? ? "itemId": "1", ? ? ? ? ? "menuChidrenItem": "所有訂單" ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "2", ? ? ? ? ? ? "menuChidrenItem": "已完成訂單" ? ? ? ? ? }, ? ? ? ? ? { ? ? ? ? ? ? "itemId": "3", ? ? ? ? ? ? "menuChidrenItem": "未完成訂單" ? ? ? ? ? } ? ? ? ? ], ? ? ? ? "showSubMenu": false ? ? ? }, ? ? ? { ? ? ? ? "id":"5", ? ? ? ? "menuName":"個(gè)人中心", ? ? ? ? "menuChildren": [ ? ? ? ? ? { ? ? ? ? ? ? "itemId": "1", ? ? ? ? ? ? "menuChidrenItem": "用戶(hù)信息修改" ? ? ? ? ? } ? ? ? ? ], ? ? ? ? "showSubMenu": false ? ? ? } ? ? ] }
ts接受數(shù)據(jù),并處理:
import { Component, OnInit } from '@angular/core'; import { HttpClient, HttpClientModule } from '@angular/common/http'; @Component({ ? selector: 'app-header', ? templateUrl: './header.component.html', ? styleUrls: ['./header.component.css'] }) export class HeaderComponent implements OnInit { ? headData: any; ? constructor( ? ? private http: HttpClient ? ) { } ? ngOnInit(): void { ? ? // http://localhost:4200/assets/json/header.json 可訪問(wèn) ? ? this.http.get('/assets/json/header.json').subscribe(data => { ? ? ? this.headData = data; ? ? ? console.log(this.headData.menu); ? ? }); ? } ? showSubMenu(item: any, index: any): void { ? ? // 設(shè)置當(dāng)前子菜單顯示 ? ? item.showSubMenu = true; ? } ? notShowSubMenu(item: any, index: any): void { ? ? // 設(shè)置當(dāng)前子菜單不顯示 ? ? item.showSubMenu = false; ? } }
html顯示控制,利用ngstyle控制:
<div class="menu_container"> ? <div id="top_title">{{headData.siteName}}</div> ? <div id="menu" *ngFor="let item of headData.menu, let i = index"> ? <!-- 第一個(gè)參數(shù)為類(lèi)名稱(chēng),第二個(gè)參數(shù)為boolean值,如果為true就添加第一個(gè)參數(shù)的類(lèi)--> ? ? <ul [ngClass]="{'sumMenu': item.showSubMenu}"> ? ? ? <!--mouseleave mouseout供選則--> ? ? ? <li class="top_nav nav_1" (mouseenter)="showSubMenu(item ,i)" (mouseleave)="notShowSubMenu(item, i)"> ? ? ? ? <span>{{item.menuName}}</span> ? ? ? ? <dl *ngFor="let child of item.menuChildren, let k = index" ? ? ? ? ? ? [ngStyle]="{'display': item.showSubMenu ? 'block':'none','margin-left': '-2.6rem'}"> ? ? ? ? ? <dd>{{child.menuChidrenItem}}</dd> ? ? ? ? </dl> ? ? ? </li> ? ? </ul> ? </div> </div>
實(shí)際效果:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Angular.Js中ng-include指令的使用與實(shí)現(xiàn)
ng-include 指令用于包含外部的 HTML 文件。包含的內(nèi)容將作為指定元素的子節(jié)點(diǎn)。下面這篇文章主要給大家介紹了Angular.Js中ng-include指令的使用與實(shí)現(xiàn)的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友們下面來(lái)一起看看吧。2017-05-05實(shí)例解析angularjs的filter過(guò)濾器
本文對(duì)angularjs的filter過(guò)濾器進(jìn)行系統(tǒng)介紹,附上實(shí)例解析,便于理解。具有很好的參考價(jià)值,需要的朋友可以看下2016-12-12用AngularJS來(lái)實(shí)現(xiàn)監(jiān)察表單按鈕的禁用效果
本篇文章主要介紹了用AngularJS來(lái)實(shí)現(xiàn)監(jiān)察表單按鈕的禁用效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2016-11-11Angular2中constructor和ngOninit的使用講解
這篇文章主要介紹了Angular2中constructor和ngOninit的使用講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05ng-repeat指令在迭代對(duì)象時(shí)的去重方法
今天小編就為大家分享一篇ng-repeat指令在迭代對(duì)象時(shí)的去重方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-10-10基于Angularjs+mybatis實(shí)現(xiàn)二級(jí)評(píng)論系統(tǒng)(仿簡(jiǎn)書(shū))
這篇文章主要為大家詳細(xì)介紹了基于Angularjs+mybatis實(shí)現(xiàn)二級(jí)評(píng)論系統(tǒng),模仿簡(jiǎn)書(shū)效果制作,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02AngularJS 路由詳解和簡(jiǎn)單實(shí)例
本文主要介紹AngularJS 路由,這里整理了相關(guān)資料進(jìn)行詳細(xì)介紹,并附實(shí)例代碼和實(shí)現(xiàn)效果圖,有需要的小伙伴可以參考下2016-07-07Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解 (上)
這篇文章主要給大家介紹了關(guān)于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編一起來(lái)看看吧。2017-07-07