天天看点

js实现当前导航菜单高亮显示

html:

<div id="navi">
<ul>
<li><a href="1.html" target="_blank" rel="external nofollow" >主页</a></li>
<li><a href="2.html" target="_blank" rel="external nofollow" >栏目1</a></li>
</ul>
</div>
           

js: 

<script type="text/javascript" language="javascript">
var nav = document.getElementById("navi");
var links = nav.getElementsByTagName("li");
var lilen = nav.getElementsByTagName("a");
var currenturl = document.location.href;
var last = 0;
for (var i=0;i<links.length;i++)
{
   var linkurl =  lilen[i].getAttribute("href");
     if(currenturl.indexOf(linkurl)!=-1)
        {
         last = i;
        }
}
         links[last].className = "hl";
</script>
           

css:

#navi ul li.hl a{
color:#123456;
}
           

注意:

1.getElementById("navi");这一句括号里的navi必须与<div id="navi">里的navi一致。

2.js代码必须加到body里,即加到导航的下面,不能加到head里,否则出错不能使用。

3.links[last].className = "hl";中的hl是高亮代码的样式类名。