溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

jQuery如何實現(xiàn)文檔樹效果

發(fā)布時間:2021-06-24 14:47:56 來源:億速云 閱讀:111 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)jQuery如何實現(xiàn)文檔樹效果的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

效果如下:

jQuery如何實現(xiàn)文檔樹效果

圖(1)點擊前

jQuery如何實現(xiàn)文檔樹效果

圖(2)點擊后

代碼如下:

<!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的左邊界直達 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.點擊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.點擊span or em的時候,看他父容器下是否有ul,如果有,讓其顯示,否則,隱藏
 $box.click(function(e){
  //當點擊的事件源是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'){//展開,讓其閉合
     //當閉合的時候,讓當前容器下,所有的em都移除open,所有的ul都隱藏;
     $parent.find('ul').hide();
     $parent.find('em').removeClass('open');
    }else{ //閉合讓其展開
     $ul.show();
     $parent.children('em').addClass('open');
    }
   }
  }
 })
</script>
</body>
</html>

感謝各位的閱讀!關(guān)于“jQuery如何實現(xiàn)文檔樹效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI