一.概述
本文介紹了JQuery巧妙實(shí)現(xiàn)多級(jí)菜單中當(dāng)前菜單不隨頁(yè)面跳轉(zhuǎn)樣式發(fā)生變化,貌似沒(méi)看懂啥意思?
看圖說(shuō)話(huà):就是點(diǎn)二級(jí)或多級(jí)菜單時(shí),父級(jí)展開(kāi),當(dāng)前菜單是被選中狀態(tài),這下明白了吧?

二.應(yīng)用場(chǎng)景
當(dāng)一個(gè)項(xiàng)目使用公共模板文件時(shí)(如上圖的左側(cè)菜單欄),我們給每個(gè)子菜單添加鏈接時(shí),點(diǎn)擊頁(yè)面跳轉(zhuǎn)樣后還是公共模板的樣式,這時(shí)就需要實(shí)現(xiàn)動(dòng)態(tài)加載當(dāng)前菜單的樣式。
三.實(shí)現(xiàn)方法
第一種:.通過(guò)php傳遞變量,模板頁(yè)面通過(guò)接收這些變量來(lái)實(shí)現(xiàn)當(dāng)前頁(yè)面的菜單選中與否,父級(jí)展開(kāi)等這些樣式
缺點(diǎn):雖然實(shí)現(xiàn)簡(jiǎn)單,但是每個(gè)頁(yè)面都需要php傳遞變量,很繁瑣,這種方法不推薦,故不再贅述!
第二種:通過(guò)比對(duì)當(dāng)前菜單里的a標(biāo)簽的href值與瀏覽器的url的值,判斷a標(biāo)簽里href屬性值是屬于瀏覽器url中的一部分,即表示包含該a標(biāo)簽的菜單應(yīng)該時(shí)被選中狀態(tài),在將樣式賦予該菜單及對(duì)應(yīng)的父級(jí)菜單。
四.舉個(gè)栗子
<ul class="sidebar-menu"> <li class="header">主菜單</li> <li class="treeview"> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <i class="fa fa-users"></i> <span>用戶(hù)管理</span> <span class="pull-right-container"> <i class="fa fa-angle-left pull-right"></i> </span> </a> <ul class="treeview-menu"> <li><a href="{{ path('agent') }}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 代理商</a></li> <li><a href="{{ path('client') }}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 委托人</a></li> <li><a href="{{ path('cs_staff') }}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 客服</a></li> <li><a href="{{ path('admin') }}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 管理員</a></li> </ul> </li> <li class="treeview"> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <i class="fa fa-bicycle"></i> <span>車(chē)輛管理</span> <span class="pull-right-container"> <i class="fa fa-angle-left pull-right"></i> </span> </a> <ul class="treeview-menu"> <li><a href="{{ path('bike') }}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 單車(chē)</a></li> </ul> </li> <li class="treeview"> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" > <i class="fa fa-fw fa-cny"></i> <span>統(tǒng)計(jì)報(bào)表</span> <span class="pull-right-container"> <i class="fa fa-angle-left pull-right"></i> </span> </a> <ul class="treeview-menu"> <li><a href="{{ path('report')}}" rel="external nofollow" ><i class="fa fa-circle-o"></i> 單車(chē)收益</a></li> </ul> </li> </ul>注:上述樣式是bootstamp的樣式
如果當(dāng)前頁(yè)面是管理員頁(yè),那個(gè)給所對(duì)應(yīng)的li添加class="active"的屬性,父級(jí)ul的樣式由style="display: none;"修改為style="display: block;",ul的父級(jí)再添加class="active"的屬性,即有了圖一的效果。
以下是我寫(xiě)的js實(shí)現(xiàn)代碼,放在公共js文件即可
var CURRENT_URL = window.location.href.split('?')[0]; CURRENT_URL_ARR=CURRENT_URL.split("/",6); for (i=0;i<CURRENT_URL_ARR.length ;i++ ){ TEM_URL = CURRENT_URL_ARR.join(","); TEM_URL = TEM_URL.replace(/,/g,"/"); $('.sidebar-menu').find('a').filter(function () { return this.href ==TEM_URL+"/"; }).parent('li').addClass('active').parent('ul').css("display","block").parent('li').addClass('active'); CURRENT_URL_ARR.pop(); }解釋?zhuān)?/p>
第1行:取得當(dāng)前url?前的地址,去除url參數(shù)
alert(CURRENT_URL);
結(jié)果為:http://partner.bike.lc/admin/
第2行:把url里按“/”再次分割成字符串?dāng)?shù)組,后面的6為了精確的找到對(duì)應(yīng)控制器及方法,按需設(shè)著
alert(CURRENT_URL_ARR);
結(jié)果為:http:,,partner.bike.lc,admin,
第3行:循環(huán)匹配url
第4行:再將數(shù)組轉(zhuǎn)化為字符串
aert(TEM_URL);
循環(huán)得到的結(jié)果依次為:
http:,,partner.bike.lc,admin,http:,,partner.bike.lc,adminhttp:,,partner.bike.lc...
第5行:將上一步字符串轉(zhuǎn)化為URL形式
aert(TEM_URL);
循環(huán)得到的結(jié)果依次為:
http://partner.bike.lc/admin/
http://partner.bike.lc/admin
http://partner.bike.lc
...
第6-10行:遍歷菜單欄里的所有a標(biāo)簽,判斷循環(huán)里的url是否有等于a標(biāo)簽的href值,如果有加上所需的樣式
注:
this.href得到的是完整的URL地址;
pop用于刪除并返回?cái)?shù)組的最后一個(gè)元素,此步很重要。
好了,以上所述是小編給大家介紹的JS實(shí)現(xiàn)多級(jí)菜單中當(dāng)前菜單不隨頁(yè)面跳轉(zhuǎn)樣式而發(fā)生變化 。不知道大家理解了沒(méi)有。主要是理解實(shí)現(xiàn)思路,樣式可根據(jù)自身情況調(diào)整~
|
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注