如何避免 CSS nth-child 选择器中的隐藏元素
使用按钮点击隐藏带有 display: none 的元素时,nth-child 选择器会同时考虑可见和隐藏项目。这可能会破坏不同行的样式模式。
说明:
CSS nth-child() 选择器根据元素在兄弟元素中的位置来匹配元素。然而,即使使用 display: none,隐藏元素仍保留在 DOM 中,导致计数不正确。
解决方案:
从第 n 个子元素计数中排除隐藏元素,您必须将它们从 DOM 中完全删除。但是,使用remove()方法会阻止它们稍后恢复,从而干扰切换功能。
替代方法:
相反,使用jQuery的detach()方法,该方法保留事件侦听器和其他元数据。操作方法如下:
var divs; $('.photos-board-item').each(function(i){ $(this).data('initial-index', i); }); $('.hide-others').on('click', function () { if(divs) { $(divs).appendTo('.row').each(function(){ var oldIndex = $(this).data('initial-index'); $('.photos-board-item').eq(oldIndex).before(this); }); divs = null; } else { divs = $('.css--all-photo').detach(); } });
说明:
此代码切换所选 div 的可见性,同时保持正确的第 n 个子级数:
- 将分离的div存储在divs变量中。
- 如果div不为空,则之前已被单击过。根据 div 的初始索引数据属性将它们按原始顺序追加回行。
- 如果 div 为空,则分离指定的 div 并将它们存储在 div 中。
优点:
- 尽管存在隐藏元素,仍保留第 n 个子级的准确性。
- 允许轻松切换可见性,而不破坏视觉设计。
- 否需要更改 HTML 或 CSS。
以上是如何从 CSS nth-child 选择器计数中排除隐藏元素?的详细内容。更多信息请关注PHP中文网其他相关文章!

文章讨论了CSS FlexBox,这是一种布局方法,用于有效地对齐和分布响应设计中的空间。它说明了FlexBox用法,将其与CSS网格进行了比较,并详细浏览了浏览器支持。

本文讨论了使用CSS创建响应网站的技术,包括视口元标签,灵活的网格,流体媒体,媒体查询和相对单元。它还涵盖了使用CSS网格和Flexbox一起使用,并推荐CSS框架

本文讨论了CSS盒装属性,该属性控制了元素维度的计算方式。它解释了诸如Content-Box,Border-Box和Padding-Box之类的值,以及它们对布局设计和形式对齐的影响。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

记事本++7.3.1
好用且免费的代码编辑器

禅工作室 13.0.1
功能强大的PHP集成开发环境

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。