|
其實思路很簡單,第一種方法是通過遍歷鏈接組的href值,通過indexOf判斷href值是否被包含在瀏覽器當前url值中.此方法有一定局限,比如對于iframe內的菜單是不能這樣判斷的; 第二種方法適用范圍更廣一樣,實現思路也比較簡單,即通過判斷點擊,給點擊項加載高亮樣式.
第一種判斷當前URL值高亮類代碼:
復制代碼 代碼如下:
//@Mr.Think---判斷URL實現菜單高亮顯示
function highURL(menuId,classCur){
if(!document.getElementById) return false;
if(!document.getElementById(menuId)) return false;
if(!document.getElementsByTagName) return false;
var menuId=document.getElementById(menuId);
var links=menuId.getElementsByTagName("a");
for(var i=0; i<links.length; i++ ){
var menuLink=links[i].href;
var currentLink=window.location.href;
if(currentLink.indexOf(menuLink)!=-1){
links[i].className=classCur;
}
}
}
參數說明:
1.menuId : 鏈接組所在ID;
2.classCur : 高亮顯示時的樣式class名.
調用方法:
window.onload=function highThis(){highURL("youId","youhighclass");}
第二種點擊后高亮顯示當前類:
復制代碼 代碼如下:
//@Mr.Think---點擊實現高亮顯示
function highOnclick(elemId,classCur) {
if (!document.getElementsByTagName) return false;
if (!document.getElementById) return false;
if (!document.getElementById(elemId)) return false;
var elemId = document.getElementById(elemId);
var links = elemId.getElementsByTagName("a");
for (i = 0; i < links.length; i++) {
links[i].onclick = function() {
for (n = 0; n < links.length; n++) {
links[n].className = "";
this.className = classCur;
this.blur();
}
}
}
}
參數說明:
1.elemId : 鏈接組所在ID;
2.classCur : 點擊后顯示的樣式class名.
調用方法:
window.onload=function highThis(){highOnclick("youId","youhighclass");}
此方法擴展性較強,比如可以通過判斷parentNode.nodeName值來使某一類型鏈接不被遍歷,等等.
源碼下載及演示
鑒于有朋友不知道如何使用,我特地整理了一下我之前寫的與這個類有關的頁面,給一個DEMO頁面和下載地址,需要的朋友可以查看或下載.
打包下載地址
JavaScript技術:兩種簡單實現菜單高亮顯示的JS類代碼,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。