:nth-child 伪类通过位置精确选择子元素,支持数字、关键字和公式;常用于隔行着色、布局控制等场景,需注意其按位置而非类型匹配的特性及 n 的起始值为 0 等细节。

:nth-child 是 CSS 中一个非常强大的伪类选择器,用于选中父元素下的第 n 个子元素。它不仅支持简单的数字定位,还能通过公式和关键词实现更复杂的匹配模式。掌握其语法和使用技巧,能让你在不修改 HTML 结构的情况下,精准控制元素样式。
基本语法结构
其基本写法为::nth-child(an + b),其中 a 和 b 是整数(可为负),n 是从 0 开始的计数变量。
- 数字值:如 :nth-child(3) 表示选中第 3 个子元素。
- 关键字:even 选中偶数项,odd 选中奇数项,常用于隔行变色。
- 公式表达式:如 :nth-child(2n+1) 等同于 odd,:nth-child(3n) 每第 3 个元素匹配一次。
常见应用场景
这个选择器特别适合处理列表、表格等重复结构的样式控制。
-
表格隔行着色:
tr:nth-child(even) { background: #f2f2f2; }
让表格偶数行有浅灰色背景,提升可读性。 -
网格布局中的周期性样式:
在每第 4 个元素后重置浮动或清除布局时使用:
.item:nth-child(4n) { margin-right: 0; } -
首尾元素特殊处理:
:nth-child(1) 可替代 :first-child,:nth-child(last) 不合法,应使用 :last-child。
注意事项与技巧
虽然功能强大,但使用时需注意其行为细节,避免误选。
立即学习“前端免费学习笔记(深入)”;
-
只看位置,不看类型:
:nth-child(2) 会选择父元素下的第二个子节点,无论它是 div、p 还是 span。若要按类型计数,应使用 :nth-of-type。 -
n 的起始值为 0:
表达式 3n+1 匹配的是当 n=0 时的第 1 个、n=1 时的第 4 个、n=2 时的第 7 个……以此类推。 -
负值的使用:
如 :nth-child(-n+3) 可匹配前 3 个元素,适用于“仅前几项应用样式”的场景。
实用组合技巧
结合其他选择器可实现更精细的控制。
-
排除特定项:
li:nth-child(n+2):not(:last-child) 可选中除第一项和最后一项外的所有 li。 -
配合类名使用:
.list-item:nth-child(odd) 只对带有 .list-item 类的奇数位元素生效。
基本上就这些。熟练运用 :nth-child 能大幅减少冗余 class,让 CSS 更简洁高效。关键是理解其基于“位置”的匹配逻辑,并善用公式和关键词组合。不复杂但容易忽略细节。










