最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Showhide list ul from divs - Stack Overflow

programmeradmin2浏览0评论

I have this code:

<ul>
 <div class="sub_cat_box"> 

 <li class="current"><a href="#">Cat 1</a></li> 
   <ul> 
     <li><a href="#">Prod1</a></li> 
     <li><a href="#">Prod1</a></li> 
   </ul> 

 </div> 

 <div class="sub_cat_box"> 

 <li class="current"><a href="#">Cat 2</a></li> 
   <ul> 
     <li><a href="#">Prod1</a></li> 
     <li><a href="#">Prod1</a></li> 
   </ul> 

  </div> 
</ul> 

I want to show/hide each child <ul> when I click the <li class='current'>. I tried with jQuery, but I didn't make it.

I have this code:

<ul>
 <div class="sub_cat_box"> 

 <li class="current"><a href="#">Cat 1</a></li> 
   <ul> 
     <li><a href="#">Prod1</a></li> 
     <li><a href="#">Prod1</a></li> 
   </ul> 

 </div> 

 <div class="sub_cat_box"> 

 <li class="current"><a href="#">Cat 2</a></li> 
   <ul> 
     <li><a href="#">Prod1</a></li> 
     <li><a href="#">Prod1</a></li> 
   </ul> 

  </div> 
</ul> 

I want to show/hide each child <ul> when I click the <li class='current'>. I tried with jQuery, but I didn't make it.

Share edited Feb 2, 2018 at 16:30 Peter Mortensen 31.6k22 gold badges110 silver badges133 bronze badges asked Nov 8, 2012 at 10:29 DimikereDimikere 531 gold badge1 silver badge2 bronze badges 2
  • 2 -1 He didn't try at all, that's what I read from his question. – aefxx Commented Nov 8, 2012 at 10:36
  • Your HTML fragment doesn't look valid; suggest you validate it and then include it in the question. – FixMaker Commented Nov 8, 2012 at 10:37
Add a ment  | 

8 Answers 8

Reset to default 5

Use jQuery to select li elements with the class selector, then bind an event handler to the click function. The bound function should find the next ul relevant to the selected element and call the toggle method upon it. By default the jQuery toggle method will toggle the visibility of an element:

$(".current").click(function(){
  $(this).next("ul").toggle();
});

Working example: http://jsfiddle/ytXFQ/

Your HTML is not correct.

Try it with this HTML structure:

<ul>
 <li class="current">
    <a href="javascript: toggleChildren('cat1');">Cat 1</a>
    <div class="sub_cat_box" id="cat1">
      <ul> 
        <li><a href="#">Prod1</a></li> 
        <li><a href="#">Prod1</a></li> 
      </ul> 
    </div>
  </li> 
</ul>

Function:

function toggleChildren(id) {

   var elem = document.getElementById(id);
   if(!elem) alert("error: not found!");
   else {

      if(elem.style.display == "block")
         elem.style.display = "none";

      else
         elem.style.display = "block";
   }
}

CSS:

.sub_cat_box {display: none;}

Your HTML is not valid (only il is allowed inside ul, and div and other uls must be inside lis). It should be something like this:

<ul>

    <li class="current"><div class="sub_cat_box"> 
       <a href="#">Cat 1</a>
       <ul> 
         <li><a href="#">Prod1</a></li> 
         <li><a href="#">Prod1</a></li> 
       </ul> 
       </div> 
      </li> 
     <li class="current">     
      <div class="sub_cat_box"> <a href="#">Cat 2</a> 
       <ul> 
         <li><a href="#">Prod1</a></li> 
         <li><a href="#">Prod1</a></li> 
       </ul>         
      </div> 
    </li>
    </ul> 

Once it is done like that, you can apply code like this:

$(".current").click(function(e){
     $(this).find('ul').toggle();
})
$('li.current').on('click', 'a', function() {
  $(this).parent().find('ul').toggle();
  return false;
});
$('li.current a').click(function(){
  $(this).parent().next('ul').slideToggle(); // or
  //$(this).parent().next('ul').toggle();
});

Use this:

$(document).on("click", "li.current > a", function(){
   $(this).next().slideToggle();
});

You can do it like this:

$('.current').next('ul').hide();​​​ // Make them hide by default
  $('.current').click(function(){
     $(this).next('ul').slideToggle();
  });

LIVE DEMO

Try this:

$("ul > li.current").on('click', 'a', function(){
      $('ul.class').children().toggle();
    });

Where class is your ul class. This is the cleanest jQuery code, I think.

发布评论

评论列表(0)

  1. 暂无评论