[jquery api 中文文档]jQuery实现文档树效果

更新时间:2021-06-26    来源:jquery    手机版     字体:

【www.bbyears.com--jquery】

情形:本类别下面有好多子类别,每个子类别下面又有好多孙类别;需求:当点击本类别时,子类别如果是显示的就让它隐藏,子类别如果是隐藏的就让它显示。

效果如下:

图(1)点击前

图(2)点击后

代码如下:

 

 代码如下

 

 

 

 第一级第一个

  

   第二级第一个

   第二级第二个

    

     第三级第一个

      

       第四级第一个

       第四级第二个

      

     

     第三级第二个

    

   

   第二级第三个

    

     第三级第一个

     第三级第二个

    

   

  

 

 第一级第一个

  

   第二级第一个

   第二级第二个

    

     第三级第一个

      

       第四级第一个

       第四级第二个

      

     

     第三级第二个

    

   

  

 

<scriptsrc="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>

 

本文来源:http://www.bbyears.com/wangyezhizuo/126083.html