JS實(shí)現(xiàn)無(wú)限級(jí)網(wǎng)頁(yè)折疊菜單(類(lèi)似樹(shù)形菜單)效果代碼
本文實(shí)例講述了JS實(shí)現(xiàn)無(wú)限級(jí)網(wǎng)頁(yè)折疊菜單(類(lèi)似樹(shù)形菜單)效果代碼。分享給大家供大家參考。具體如下:
這是一款超不錯(cuò)的網(wǎng)頁(yè)折疊菜單,采用JavaScript實(shí)現(xiàn)。折疊菜單是大家比較常見(jiàn)到的一種菜單形式,可廣泛應(yīng)用于管理系統(tǒng)、后臺(tái)左側(cè)、產(chǎn)品列表中,本折疊菜單有點(diǎn)樹(shù)形菜單的味道,相信“無(wú)限級(jí)”會(huì)滿(mǎn)足你的要求。
運(yùn)行效果截圖如下:

在線(xiàn)演示地址如下:
http://demo.jb51.net/js/2015/js-unlimit-fade-in-out-tree-menu-codes/
具體代碼如下:
<html>
<head>
<title>無(wú)限級(jí)折疊菜單JS版</title>
<style>
<!--
body,ul,h3 {margin:0px; padding:0px;}
li {list-style-type:none;}
body{
font-size:12px;
color:#333;
font-family: Simsun;
line-height:15px;
}
a{text-decoration:none;color:#004285;border:none;}
a:hover{text-decoration:none;color:#C33;}
#menu {
width:260px;
margin:50px auto;
padding:10px;
border:#EEE 1px solid;
}
#menu h3 {
font-size:12px;
}
#menu ul {
background:url("images/ul-bg.gif") repeat-y 5px 0px; overflow:hidden;
}
#menu ul li {
padding:5px 0 2px 15px;
background:url("images/tree-ul-li.gif") no-repeat 5px -32px;
}
#menu ul li ul {display:none;}
#menu ul li em {
cursor:pointer;
display:inline-block;
width:15px;
float:left;
height:15px;
margin-left:-14px;
background:url("images/tree-ul-li.gif") no-repeat -32px 2px;
}
#menu ul li em.off {
background-position: -17px -18px;
}
#menu ul li#end {
background-color:#FFF;
}
#menu ul.off {
display:block;
}
-->
</style>
</head>
<body>
<div id="menu">
<h3>無(wú)限級(jí)折疊菜單JavaScript版</h3>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_1_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_2_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_3_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_3_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_2_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_3_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_3_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_1_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_2_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_3_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_3_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_2_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_3_1</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_3_2</a>
<ul>
<li><em></em><a href='javascript:void(0);'>菜單_4_1</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
<li id='end'><em></em><a href='javascript:void(0);'>菜單_4_2</a>
<ul>
<li><a href='javascript:void(0);'>菜單_5_1</a></li>
<li id='end'><a href='javascript:void(0);'>菜單_5_2</a></li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</div>
<script type="text/javascript">
(function(e){
for(var _obj=document.getElementById(e.id).getElementsByTagName(e.tag),i=-1,em;em=_obj[++i];){
em.onclick = function(){ //onmouseover
var ul = this.nextSibling;
if(!ul){return false;}
ul = ul.nextSibling; if(!ul){return false;}
if(e.tag != 'a'){ ul = ul.nextSibling; if(!ul){return false;} } //a 標(biāo)簽控制 隱藏或刪除該行
for(var _li=this.parentNode.parentNode.childNodes,n=-1,li;li=_li[++n];){
if(li.tagName=="LI"){
for(var _ul=li.childNodes,t=-1,$ul;$ul=_ul[++t];){
switch($ul.tagName){
case "UL":
$ul.className = $ul!=ul?"" : ul.className?"":"off";
break;
case "EM":
$ul.className = $ul!=this?"" : this.className?"":"off";
break;
}
}
}
}
}
}
})({id:'menu',tag:'em'});
</script>
</body>
</html>
希望本文所述對(duì)大家的JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
JS如何在不同平臺(tái)實(shí)現(xiàn)多語(yǔ)言方式
這篇文章主要介紹了JS如何在不同平臺(tái)實(shí)現(xiàn)多語(yǔ)言方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
iphone safari不支持position fixed的解決方法
最近一直在做移動(dòng)web開(kāi)發(fā),開(kāi)發(fā)過(guò)程中遇到了許多問(wèn)題,mobile safari不支持position: fixed就是一件很頭疼的事情2012-05-05
js實(shí)現(xiàn)獲取div坐標(biāo)的方法
這篇文章主要介紹了js實(shí)現(xiàn)獲取div坐標(biāo)的方法,通過(guò)調(diào)用jQuery插件實(shí)現(xiàn)獲取div元素坐標(biāo)的功能,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-11-11
Javascript前端UI框架Kit使用指南之kitjs的對(duì)話(huà)框組件
本文以kitjs對(duì)話(huà)框組件為例,給我們?cè)敿?xì)介紹了kitjs的組件目錄、默認(rèn)代碼模板、構(gòu)造器及初始方法、以及Kitjs繼承。講解的非常細(xì)致,對(duì)我們熟練掌握kitjs組件很有幫助。2014-11-11
Javascript實(shí)現(xiàn)關(guān)閉廣告效果
這篇文章主要為大家詳細(xì)介紹了Javascript實(shí)現(xiàn)關(guān)閉廣告效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-01-01

