jQuery實現(xiàn)文檔樹效果
情形:本類別下面有好多子類別,每個子類別下面又有好多孫類別;需求:當(dāng)點(diǎn)擊本類別時,子類別如果是顯示的就讓它隱藏,子類別如果是隱藏的就讓它顯示。
效果如下:

圖(1)點(diǎn)擊前

圖(2)點(diǎn)擊后
代碼如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
margin:0;
padding:0;
list-style: none;
}
.box{
width: 250px;
height: auto;
padding: 20px;
background: lightgrey;
margin:0 auto;
}
.box li{
line-height: 30px;
/*注意:height沒有被設(shè)置,可以根據(jù)實際需要自動調(diào)整*/
position: relative;
}
.box li em{
position: absolute;
left:0;
top:7px;
width: 16px;
height: 16px;
background-image: url("http://www.qdfuns.com/misc.php?mod=attach&genre=editor&aid=123b5048273b92eb544ad6eb0ed57c44");
background-size:100%;
cursor: pointer;
}
.box li em.open{
background-image: url("http://www.qdfuns.com/misc.php?mod=attach&genre=editor&aid=8f89447399822b0294ae590ccc641bf5");
background-size:100%;
}
.box li span{
padding-left: 20px;
/*因為span前面的em已經(jīng)絕對定位,脫離文檔流了,所以span的左邊界直達(dá) li*/
}
.box ul{
display: none;
}
.two{
margin-left: 20px;
}
.three{
margin-left: 40px;
}
.four{
margin-left: 40px;
}
/*ul.box下的li顯示,其中有折疊的li加em;
ul.box下的ul隱藏,其內(nèi)部的li是沒法顯示的*/
</style>
</head>
<body>
<ul class="box">
<li><em></em><span>第一級第一個</span>
<ul class="two">
<li><span>第二級第一個</span></li>
<li><em></em><span>第二級第二個</span>
<ul class="three">
<li><em></em><span>第三級第一個</span>
<ul class="four">
<li><span>第四級第一個</span></li>
<li><span>第四級第二個</span></li>
</ul>
</li>
<li><span>第三級第二個</span></li>
</ul>
</li>
<li><em></em><span>第二級第三個</span>
<ul class="three">
<li><span>第三級第一個</span></li>
<li><span>第三級第二個</span></li>
</ul>
</li>
</ul>
</li>
<li><em></em><span>第一級第一個</span>
<ul class="two">
<li><span>第二級第一個</span></li>
<li><em></em><span>第二級第二個</span>
<ul class="three">
<li><em></em><span>第三級第一個</span>
<ul class="four">
<li><span>第四級第一個</span></li>
<li><span>第四級第二個</span></li>
</ul>
</li>
<li><span>第三級第二個</span></li>
</ul>
</li>
</ul>
</li>
</ul>
<script src="http://s0.kuaizhan.com/res/skin/js/lib/jquery-2.0.3.min.js"></script>
<script>
/*思路:
* 1.讓前面有em的span加上小手效果;
* 2.點(diǎn)擊span or em的時候,看他父容器下是否有ul,如果有,讓其顯示,否則,隱藏
* */
var $box=$('.box');
var $aSpan=$box.find('span');
//1.讓前面有em的span加上小手效果;
$aSpan.each(function(index,item){
//if($(item).prev().length){ $(item).css('cursor','pointer');};思路1:
$(item).prev('em').next('span').css('cursor','pointer'); //思路2:
});
//2.點(diǎn)擊span or em的時候,看他父容器下是否有ul,如果有,讓其顯示,否則,隱藏
$box.click(function(e){
//當(dāng)點(diǎn)擊的事件源是em or span的時候,我們看其父級下是否有ul
// 如果有:展開讓其閉合,閉合就讓其展開;
if(e.target.tagName.toLowerCase()=='em' || e.target.tagName.toLowerCase()=='span'){
var $parent=$(e.target).parent();
var $ul=$parent.children('ul');
if($ul){
if($ul.css('display')=='block'){//展開,讓其閉合
//當(dāng)閉合的時候,讓當(dāng)前容器下,所有的em都移除open,所有的ul都隱藏;
$parent.find('ul').hide();
$parent.find('em').removeClass('open');
}else{ //閉合讓其展開
$ul.show();
$parent.children('em').addClass('open');
}
}
}
})
</script>
</body>
</html>
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關(guān)文章
jQuery向后臺傳入json格式數(shù)據(jù)的方法
這篇文章主要介紹了jQuery向后臺傳入json格式數(shù)據(jù)的方法,實例分析了傳遞json格式數(shù)據(jù)的原理與具體實現(xiàn)技巧,具有一定的參考借鑒價值,需要的朋友可以參考下2015-02-02
Jquery左右滑動插件之實現(xiàn)超級炫酷動畫效果附源碼下載
這是一款基于jquery.pogo-slider插件實現(xiàn)的多個滑塊切換特效。本篇文章給大家介紹Jquery左右滑動插件之實現(xiàn)超級炫酷動畫效果,對jquery左右滑動插件相關(guān)知識感興趣的朋友參考下2015-12-12
jQuery插件jFade實現(xiàn)鼠標(biāo)經(jīng)過的圖片高亮其它變暗
本文給大家介紹的是一款重點(diǎn)突出的jQuery特效插件效果,使用jFade實現(xiàn)鼠標(biāo)經(jīng)過的圖片高亮其它變暗,非常實用,推薦給小伙伴們參考下。2015-03-03
基于jquery實現(xiàn)的定時顯示與隱藏div廣告的實現(xiàn)代碼
有時候我們需要在jquery中要顯示與隱藏層,很簡單的方法就是直接使用hide與show方法就可以了,但要定時我們需要結(jié)合setTimeout函數(shù)來實現(xiàn)2013-08-08
jquery仿京東導(dǎo)航/仿淘寶商城左側(cè)分類導(dǎo)航下拉菜單效果
jquery實現(xiàn)下拉菜單效果,jquery寫的仿京東導(dǎo)航菜單,一個經(jīng)典的左側(cè)多級導(dǎo)航菜單,學(xué)會了可以任意改變布局,感興趣的朋友可以參考下哈,希望對你有所幫助2013-04-04
jquery+css3實現(xiàn)熊貓tv導(dǎo)航代碼分享
本篇文章給大家詳細(xì)分享的是jquery+css3來寫出熊貓tv導(dǎo)航的效果,以及代碼分享,喜歡的朋友參考下。2018-02-02

