欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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í)也希望多多支持腳本之家!

相關(guān)文章

  • jquery實(shí)現(xiàn)輪播圖特效

    jquery實(shí)現(xiàn)輪播圖特效

    這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)輪播圖特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • 實(shí)測(cè)jquery data()如何存值

    實(shí)測(cè)jquery data()如何存值

    jQuery的數(shù)據(jù)框架沒有將元素?cái)?shù)據(jù)當(dāng)作元素屬性來存儲(chǔ),我記得是可以通過jQuery的data("xxx")方法取HTML標(biāo)簽上的data-xxx屬性的值的
    2013-08-08
  • 使用jQuery fancybox插件打造一個(gè)實(shí)用的數(shù)據(jù)傳輸模態(tài)彈出窗體

    使用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-01
  • jQuery 浮動(dòng)導(dǎo)航菜單適合購物商品類型的網(wǎng)站

    jQuery 浮動(dòng)導(dǎo)航菜單適合購物商品類型的網(wǎng)站

    頁面長(zhǎng)度較大,需要方便快速的在頁面的不同位置進(jìn)行定位,所以浮動(dòng)菜單逐漸流行了起來,下面是jQuery浮動(dòng)導(dǎo)航菜單適合購物網(wǎng)站商品類型
    2014-09-09
  • Jquery 分頁插件之Jquery Pagination

    Jquery 分頁插件之Jquery Pagination

    實(shí)用jQuery分頁特效插件jquery.pagination.js,基于jQuery實(shí)現(xiàn),本文給大家分享jquery分頁插件之jquery pagination,需要的朋友可以參考下
    2015-08-08
  • jQuery延遲加載圖片插件Lazy Load使用指南

    jQuery延遲加載圖片插件Lazy Load使用指南

    在頁面上圖片比較多的時(shí)候,打開一張頁面必然引起與服務(wù)器大數(shù)據(jù)量的交互。尤其是對(duì)于高清晰的圖片,占了幾百K的空間。那么我們?nèi)绾尾拍芨淖冞@種狀況呢,這就是今天我們要探討的問題了。
    2015-03-03
  • jquery 屬性選擇器(匹配具有指定屬性的元素)

    jquery 屬性選擇器(匹配具有指定屬性的元素)

    本文主要介紹 jquery 屬性選擇器的知識(shí),這里有簡(jiǎn)單實(shí)現(xiàn)代碼和實(shí)例講解,有需要的小伙伴可以參考下
    2016-09-09
  • 基于jQuery的仿flash的廣告輪播代碼

    基于jQuery的仿flash的廣告輪播代碼

    很多網(wǎng)站的首頁都有廣告輪播,今天閑來看了一網(wǎng)站的首頁廣告輪播方式,是通過 jQuery的blockSlide插件實(shí)現(xiàn)的,然后自己測(cè)試了一下,很好。
    2010-11-11
  • jquery+ajax請(qǐng)求且?guī)Х祷刂档拇a

    jquery+ajax請(qǐng)求且?guī)Х祷刂档拇a

    這兩天的工作內(nèi)容不多,基本是關(guān)于jquery中ajax的。之前一直都是寫的最簡(jiǎn)單的ajax請(qǐng)求,并沒關(guān)注怎么獲取ajax返回值的問題。
    2015-08-08
  • jQuery中mouseover事件用法實(shí)例

    jQuery中mouseover事件用法實(shí)例

    這篇文章主要介紹了jQuery中mouseover事件用法,以實(shí)例形式分析了mouseover事件處理鼠標(biāo)指針滑過時(shí)的使用技巧,需要的朋友可以參考下
    2014-12-12

最新評(píng)論