jQuery實(shí)現(xiàn)文檔樹效果
更新時(shí)間:2017年02月20日 17:00:34 作者:前端工程師_錢成
本文主要分享了jQuery實(shí)現(xiàn)文檔樹效果的示例代碼,具有很好的參考價(jià)值,下面跟著小編一起來看下吧
情形:本類別下面有好多子類別,每個(gè)子類別下面又有好多孫類別;需求:當(dāng)點(diǎn)擊本類別時(shí),子類別如果是顯示的就讓它隱藏,子類別如果是隱藏的就讓它顯示。
效果如下:
圖(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ù)實(shí)際需要自動(dòng)調(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; /*因?yàn)閟pan前面的em已經(jīng)絕對(duì)定位,脫離文檔流了,所以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>第一級(jí)第一個(gè)</span> <ul class="two"> <li><span>第二級(jí)第一個(gè)</span></li> <li><em></em><span>第二級(jí)第二個(gè)</span> <ul class="three"> <li><em></em><span>第三級(jí)第一個(gè)</span> <ul class="four"> <li><span>第四級(jí)第一個(gè)</span></li> <li><span>第四級(jí)第二個(gè)</span></li> </ul> </li> <li><span>第三級(jí)第二個(gè)</span></li> </ul> </li> <li><em></em><span>第二級(jí)第三個(gè)</span> <ul class="three"> <li><span>第三級(jí)第一個(gè)</span></li> <li><span>第三級(jí)第二個(gè)</span></li> </ul> </li> </ul> </li> <li><em></em><span>第一級(jí)第一個(gè)</span> <ul class="two"> <li><span>第二級(jí)第一個(gè)</span></li> <li><em></em><span>第二級(jí)第二個(gè)</span> <ul class="three"> <li><em></em><span>第三級(jí)第一個(gè)</span> <ul class="four"> <li><span>第四級(jí)第一個(gè)</span></li> <li><span>第四級(jí)第二個(gè)</span></li> </ul> </li> <li><span>第三級(jí)第二個(gè)</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的時(shí)候,看他父容器下是否有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的時(shí)候,看他父容器下是否有ul,如果有,讓其顯示,否則,隱藏 $box.click(function(e){ //當(dāng)點(diǎn)擊的事件源是em or span的時(shí)候,我們看其父級(jí)下是否有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)閉合的時(shí)候,讓當(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>
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
您可能感興趣的文章:
- jQuery仿寫百度百科的目錄樹
- jquery實(shí)現(xiàn)的樹形目錄實(shí)例
- jQuery遍歷節(jié)點(diǎn)樹方法分析
- jQuery樹形控件zTree使用小結(jié)
- 多功能jQuery樹插件zTree實(shí)現(xiàn)權(quán)限列表簡(jiǎn)單實(shí)例
- jquery樹形菜單效果的簡(jiǎn)單實(shí)例
- jQuery zTree加載樹形菜單功能
- jquery實(shí)現(xiàn)樹形菜單完整代碼
- 輕松學(xué)習(xí)jQuery插件EasyUI EasyUI創(chuàng)建樹形菜單
- jquery插件treegrid樹狀表格的使用方法詳解(.Net平臺(tái))
相關(guān)文章
使用jQuery fancybox插件打造一個(gè)實(shí)用的數(shù)據(jù)傳輸模態(tài)彈出窗體
模態(tài)窗體已經(jīng)成為Web開發(fā)人員設(shè)計(jì)界面時(shí)經(jīng)常要使用的傳輸數(shù)據(jù)的方式;通過模態(tài)窗口,可以提高網(wǎng)站的可用性;你可以在你的郵件里收到用戶發(fā)送的反饋消息2013-01-01jQuery 浮動(dòng)導(dǎo)航菜單適合購物商品類型的網(wǎng)站
頁面長(zhǎng)度較大,需要方便快速的在頁面的不同位置進(jìn)行定位,所以浮動(dòng)菜單逐漸流行了起來,下面是jQuery浮動(dòng)導(dǎo)航菜單適合購物網(wǎng)站商品類型2014-09-09jquery+ajax請(qǐng)求且?guī)Х祷刂档拇a
這兩天的工作內(nèi)容不多,基本是關(guān)于jquery中ajax的。之前一直都是寫的最簡(jiǎn)單的ajax請(qǐng)求,并沒關(guān)注怎么獲取ajax返回值的問題。2015-08-08