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

二.應用場景
當一個項目使用公共模板文件時(如上圖的左側(cè)菜單欄),我們給每個子菜單添加鏈接時,點擊頁面跳轉(zhuǎn)樣后還是公共模板的樣式,這時就需要實現(xiàn)動態(tài)加載當前菜單的樣式。
三.實現(xiàn)方法
第一種:.通過php傳遞變量,模板頁面通過接收這些變量來實現(xiàn)當前頁面的菜單選中與否,父級展開等這些樣式
缺點:雖然實現(xiàn)簡單,但是每個頁面都需要php傳遞變量,很繁瑣,這種方法不推薦,故不再贅述!
第二種:通過比對當前菜單里的a標簽的href值與瀏覽器的url的值,判斷a標簽里href屬性值是屬于瀏覽器url中的一部分,即表示包含該a標簽的菜單應該時被選中狀態(tài),在將樣式賦予該菜單及對應的父級菜單。
四.舉個栗子
<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)計報表</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的樣式
如果當前頁面是管理員頁,那個給所對應的li添加class="active"的屬性,父級ul的樣式由style="display: none;"修改為style="display: block;",ul的父級再添加class="active"的屬性,即有了圖一的效果。
以下是我寫的js實現(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行:取得當前url?前的地址,去除url參數(shù)
alert(CURRENT_URL);
結(jié)果為:http://partner.bike.lc/admin/
第2行:把url里按“/”再次分割成字符串數(shù)組,后面的6為了精確的找到對應控制器及方法,按需設(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標簽,判斷循環(huán)里的url是否有等于a標簽的href值,如果有加上所需的樣式
注:
this.href得到的是完整的URL地址;
pop用于刪除并返回數(shù)組的最后一個元素,此步很重要。
好了,以上所述是小編給大家介紹的JS實現(xiàn)多級菜單中當前菜單不隨頁面跳轉(zhuǎn)樣式而發(fā)生變化 。不知道大家理解了沒有。主要是理解實現(xiàn)思路,樣式可根據(jù)自身情況調(diào)整~
多種方式實現(xiàn)JS調(diào)用后臺方法進行數(shù)據(jù)交互
xmlplus組件設(shè)計系列之路由(ViewStack)(7)
firefox事件處理之自動查找event的函數(shù)(用于onclick=foo())

