javascript - 仅隐藏和显示直接子项的第 n 项之后的 div 列表项

标签 javascript jquery toggle

假设我有一个无序列表,如下所示:

Demo

HTML 代码:

<ul>
  <li>One
  <ul>
  <li>on 1.1</li>
  <li>on 1.2</li>
  <li>on 1.3</li>
  </ul>
  </li>
  <li>Two</li>
  <li>Three</li>
  <li>Four</li>
  <li>Five</li>
  <li>One 1</li>
  <li>Two 2</li>
  <li>Three 3</li>
  <li>Four 4</li>
  <li>Five 5</li>
  <li>One 11</li>
  <li>Two 22</li>
  <li>Three 33</li>
  <li>Four 44</li>
  <li>Five 55</li>
</ul>
<span class="show_more">see more</span>

脚本文件:

$('.nav_accordian').each(function(){
    var max = 4
    if ($(this).find('li').length > max) {
        $(this).find('li:gt('+max+')').hide().end().append('<li class="sub_accordian"><span class="show_more">(see more)</span></li>');

        $('.sub_accordian').click( function(){
            $(this).siblings(':gt('+max+')').toggle();

            if ( $('.show_more').length ) {
                $(this).html('<span class="showMore">show More</span>');
            } 
            else {
                $(this).html('<span class="showMore">less More</span>');
            };
        });
    };
});

我这样做是因为当我单击“显示更多”时,应该可以看到列表项的下五个结果。一旦每个结果加载,“显示更多”文本将更改为“更少更多”。

当我点击“少更多”按钮时,第一个结果结果项目应该是可见的,其他项目将被隐藏。

问题是脚本也考虑了 li 的子列表

最佳答案

为您想要依赖的列表元素提供一个类应该可以解决您的问题:

<ul>
  <li class="list__element">One
  <ul>
  <li>on 1.1</li>
  <li>on 1.2</li>
  <li>on 1.3</li>
  </ul>
  </li>
  <li class="list__element">Two</li>
  <li class="list__element">Three</li>
  <li class="list__element">Four</li>
  <li class="list__element">Five</li>
  <li class="list__element">One 1</li>
  <li class="list__element">Two 2</li>
  <li class="list__element">Three 3</li>
  <li class="list__element">Four 4</li>
  <li class="list__element">Five 5</li>
  <li class="list__element">One 11</li>
  <li class="list__element">Two 22</li>
  <li class="list__element">Three 33</li>
  <li class="list__element">Four 44</li>
  <li class="list__element">Five 55</li>
</ul>
<span class="show_more">see more</span>

在你的JS中你会计算“.list__element”,就像这样:

if ($(this).find('.list__element').length > max) {
...
}

关于javascript - 仅隐藏和显示直接子项的第 n 项之后的 div 列表项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35897166/

相关文章:

javascript - 如何使用 Firebase 实时数据库将信息从一个用户发送到另一用户?

单击时 JavaScript 不工作

javascript - 如何将按钮放入 select2 结果项并处理其点击?

javascript - 无法让名为 "kareoke"的函数工作

javascript - AngularJS:一次加载所有数据作为 JSON 与使用数据库并仅加载部分数据。什么是更好的?

javascript - 棘手的拉斐尔 svg 动画

javascript - 从值为零的对象中删除属性

javascript - Kendo UI Grid 多层层次结构(n-levels of hierarchy)

javascript - 适当调整一页上的多个切换

javascript - 显示/隐藏单选按钮,基于其他单选按钮