JS實(shí)現(xiàn)多級(jí)菜單中當(dāng)前菜單不隨頁面跳轉(zhuǎn)樣式而發(fā)生變化
一.概述
本文介紹了JQuery巧妙實(shí)現(xiàn)多級(jí)菜單中當(dāng)前菜單不隨頁面跳轉(zhuǎn)樣式發(fā)生變化,貌似沒看懂啥意思?
看圖說話:就是點(diǎn)二級(jí)或多級(jí)菜單時(shí),父級(jí)展開,當(dāng)前菜單是被選中狀態(tài),這下明白了吧?
二.應(yīng)用場(chǎng)景
當(dāng)一個(gè)項(xiàng)目使用公共模板文件時(shí)(如上圖的左側(cè)菜單欄),我們給每個(gè)子菜單添加鏈接時(shí),點(diǎn)擊頁面跳轉(zhuǎn)樣后還是公共模板的樣式,這時(shí)就需要實(shí)現(xiàn)動(dòng)態(tài)加載當(dāng)前菜單的樣式。
三.實(shí)現(xiàn)方法
第一種:.通過php傳遞變量,模板頁面通過接收這些變量來實(shí)現(xiàn)當(dāng)前頁面的菜單選中與否,父級(jí)展開等這些樣式
缺點(diǎn):雖然實(shí)現(xiàn)簡(jiǎn)單,但是每個(gè)頁面都需要php傳遞變量,很繁瑣,這種方法不推薦,故不再贅述!
第二種:通過比對(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>用戶管理</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>車輛管理</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> 單車</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> 單車收益</a></li> </ul> </li> </ul>
注:上述樣式是bootstamp的樣式
如果當(dāng)前頁面是管理員頁,那個(gè)給所對(duì)應(yīng)的li添加class="active
"的屬性,父級(jí)ul的樣式由style="display: none;"
修改為style="display: block;",
ul的父級(jí)再添加class="active"的屬性,即有了圖一的效果。
以下是我寫的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(); }
解釋:
第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,admin http:,,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)前菜單不隨頁面跳轉(zhuǎn)樣式而發(fā)生變化 。不知道大家理解了沒有。主要是理解實(shí)現(xiàn)思路,樣式可根據(jù)自身情況調(diào)整~
相關(guān)文章

正則表達(dá)式基本語法及表單驗(yàn)證操作詳解【基于JS】

多種方式實(shí)現(xiàn)JS調(diào)用后臺(tái)方法進(jìn)行數(shù)據(jù)交互

微信小程序?qū)崿F(xiàn)婚禮邀請(qǐng)函全部流程

Bootstrap實(shí)現(xiàn)的表格合并單元格示例

xmlplus組件設(shè)計(jì)系列之路由(ViewStack)(7)

firefox事件處理之自動(dòng)查找event的函數(shù)(用于onclick=foo())

JavaScript實(shí)現(xiàn)緩動(dòng)動(dòng)畫