0

0

css nth-child 选择器怎么理解_序号选择规则解析

P粉602998670

P粉602998670

发布时间:2026-01-25 13:08:02

|

954人浏览过

|

来源于php中文网

原创

:nth-child()的“序号”指元素在父元素所有子节点中的绝对位置(从1开始),与类型、可见性、类名无关;如中ABC,第二个li是第3个子元素,需用li:nth-child(3)。

css nth-child 选择器怎么理解_序号选择规则解析

什么是 :nth-child() 的“序号”?

这个序号不是你肉眼看到的第几个 li 或第几个 div,而是它在**父元素所有子节点中的绝对位置**——从 1 开始数,不管类型、不管是否隐藏、不管有没有类名。

  • 如果父元素是
      ,里面依次是
    • A
    • B

    • C
    • ,那么第二个 li(即 C)其实是父元素的第 3 个子元素,li:nth-child(3) 才能选中它
    • li:nth-child(2) 在这个例子里会失效,因为第 2 个子元素是 p,不是 li
    • 空格、换行、注释在 HTML 中也会生成文本节点,但现代浏览器通常忽略它们对 :nth-child() 计数的影响;不过嵌入了 标签时,它们会被计入子元素总数

    an + b 公式到底怎么算?

    别被公式吓住:浏览器会把 n 从 0 开始代入,只要结果 ≥ 1,就对应一个有效位置。关键看 a(步长)和 b(起点)怎么配合。

    • :nth-child(3n) → n=0→0(跳过),n=1→3,n=2→6,n=3→9…… → 选第 3、6、9… 个子元素
    • :nth-child(3n+1) → n=0→1,n=1→4,n=2→7…… → 选第 1、4、7… 个子元素
    • :nth-child(-n+3) → n=0→3,n=1→2,n=2→1,n=3→0(停)→ 实际选第 1、2、3 个子元素(常用于“前 N 个”)
    • odd 等价于 2n+1even 等价于 2n,但写关键字更直观、不易出错

    为什么明明写了 div:nth-child(2) 却没生效?

    这是最常踩的坑:选择器要求「既是第 n 个子元素,又匹配前面的标签/类名」。二者缺一不可。

    Originality AI
    Originality AI

    专门为网络出版商设计的抄袭和AI检测工具

    下载

    立即学习前端免费学习笔记(深入)”;

    • 父元素内子节点顺序是:

      标题

      内容
      说明 → 那么 div:nth-child(2) ✅ 成功匹配
    • 如果顺序变成:
      内容
      说明 → 第 2 个子元素确实是 div,仍 ✅ 匹配
    • 但如果顺序是:提示
      内容
      → 第 2 个子元素是 divdiv:nth-child(2) ✅ 仍成立
    • 但若写成 .item:nth-child(2),而第 2 个子元素是
      ,那就 ❌ 不匹配——类名必须同时满足位置和类型约束

      什么时候该换用 :nth-of-type()

      当你真正想选的是“同类型中的第 n 个”,而不是“所有子元素中的第 n 个”,就该切换了。

      • 场景:父元素混排了 pdivpsectionp,你想给**第三个 p** 加粗 → 用 p:nth-of-type(3),不是 p:nth-child(5)(它依赖结构稳定,易断)
      • :nth-of-type(n) 只统计同标签名的兄弟元素,自动跳过其他类型,语义更贴近直觉
      • 注意::nth-of-type() 不支持类名或属性筛选,只能基于元素类型(divp 等)

      真正难的不是记住公式,而是每次写之前先快速扫一眼父容器的 DOM 结构——打开开发者工具,把鼠标悬停在父元素上,看它的子节点列表,数清楚哪个位置是什么元素。这一步省掉,后面全靠猜。

    相关专题

    更多
    css
    css

    css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

    524

    2023.06.15

    css居中
    css居中

    css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

    268

    2023.07.27

    css如何插入图片
    css如何插入图片

    cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

    761

    2023.07.28

    css超出显示...
    css超出显示...

    在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

    540

    2023.08.01

    css字体颜色
    css字体颜色

    CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

    762

    2023.08.10

    什么是css
    什么是css

    CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

    606

    2023.08.10

    css三角形怎么写
    css三角形怎么写

    CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

    561

    2023.08.21

    css设置文字颜色
    css设置文字颜色

    CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

    397

    2023.08.22

    c++ 根号
    c++ 根号

    本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

    41

    2026.01.23

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Sass 教程
    Sass 教程

    共14课时 | 0.8万人学习

    Bootstrap 5教程
    Bootstrap 5教程

    共46课时 | 3万人学习

    CSS教程
    CSS教程

    共754课时 | 23.4万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号