css nth-child 选择器怎么理解_序号选择规则解析
技术百科
P粉602998670
发布时间:2026-01-25
浏览: 次 :nth-child()的“序号”指元素在父元素所有子节点中的绝对位置(从1开始),与类型、可见性、类名无关;如中ABC,第二个li是第3个子元素,需用li:nth-child(3)。
什么是 :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+1,even等价于2n,但写关键字更直观、不易出错
为什么明明写了 div:nth-child(2) 却没生效?
这是最常踩的坑:选择器要求「既是第 n 个子元素,又匹配前面的标签/类名」。二者缺一不可。
- 父元素内子节点顺序是:
、标题
内容、说明→ 那么div:nth-child(2)✅ 成功匹配 - 如果顺序变成:
…、内容、说明→ 第 2 个子元素确实是div,仍 ✅ 匹配 - 但如果顺序是:
提示、内容→ 第 2 个子元素是div,div:nth-✅ 仍成立
child(2)
- 但若写成
.item:nth-child(2),而第 2 个子元素是,那就 ❌ 不匹配——类名必须同时满足位置和类型约束什么时候该换用
:nth-of-type()?当你真正想选的是“同类型中的第 n 个”,而不是“所有子元素中的第 n 个”,就该切换了。
- 场景:父元素混排了
p、div、p、section、p,你想给**第三个p** 加粗 → 用p:nth-of-type(3),不是p:nth-child(5)(它依赖结构稳定,易断) -
:nth-of-type(n)只统计同标签名的兄弟元素,自动跳过其他类型,语义更贴近直觉 - 注意:
:nth-of-type()不支持类名或属性筛选,只能基于元素类型(div、p等)
真正难的不是记住公式,而是每次写之前先快速扫一眼父容器的 DOM 结构——打开开发者工具,把鼠标悬停在父元素上,看它的子节点列表,数清楚哪个位置是什么元素。这一步省掉,后面全靠猜。
- 场景:父元素混排了
# 的是
# 几个
# 这是
# 在这个
# 那就
# 也会
# 跳过
# 第二个
# 什么时候
# 浏览器
# css
# 选择器
# 鼠标
# 工具
# class
# html
# 为什么
# dom
# ul
# li
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Linux怎么修改用户密码_Linux系统pass
- Linux怎么查找死循环进程_Linux系统负载分
- Go语言中slice追加操作的底层共享机制解析
- C++中的std::shared_from_thi
- Windows10如何删除Windows.old_
- PhpStorm怎么调试PHP代码_PhpStor
- Windows蓝屏错误0x0000001E怎么修复
- Win11如何设置省电模式 Win11开启电池节电
- PythonGIL机制理解_多线程限制解析【教程】
- Win11怎么关闭触摸键盘图标_Windows11
- c++怎么编写动态链接库dll_c++ __dec
- Python深度学习实战教程_神经网络模型构建与训
- php下载安装包怎么选_threadsafe与nt
- 如何处理“XML格式不正确”错误 常见XML we
- PyTorch DDP 多进程训练在 Kaggle
- Win11怎么关闭自动修复_跳过Win11开机自动
- PHP主流架构怎么监控运行状态_工具推荐【操作】
- Linux怎么设置磁盘配额_Linux系统Quot
- 如何使用Golang recover捕获panic
- Win11怎么关闭搜索历史 Win11清除搜索框最
- Win11怎么调整屏幕亮度_Windows 11调
- Win11怎么制作U盘启动盘_Win11原版系统安
- c++如何连接Redis c++ hiredis库
- Win11键盘快捷键大全_Windows 11常用
- php485函数执行慢怎么优化_php485性能提
- 如何使用Golang实现云原生应用弹性伸缩_自动应
- c++怎么操作redis数据库_c++ hired
- Win11怎么检查TPM2.0模块_Windows
- Win11搜索栏无法输入_解决Win11开始菜单搜
- PHP主流架构如何做单元测试_工具与流程【详解】
- MAC怎么在照片中添加水印_MAC自带编辑工具文字
- 如何在Golang中理解指针比较_Golang地址
- 如何使用Golang读取日志文件_Golang b
- Win11怎么恢复旧版开始菜单_通过软件还原Win
- Windows怎样关闭Edge新标签页广告_Win
- php与c语言在嵌入式中有何区别_对比两者在硬件控
- Flask 表单数据通过 SMTP 发送邮件的完整
- c# 在ASP.NET Core中管理和取消后台任
- 如何用正则表达式精确匹配最多含一个换行符的起止片段
- Win11怎么开启游戏工具栏_Windows11
- C++ static_cast和dynamic_c
- 如何在Golang中编写异步函数测试_Golang
- Win11怎么关闭自动调节亮度 Win11禁用内容
- c++20的std::format怎么用 比pri
- C#如何使用XPathNavigator高效查询X
- Mac怎么开启“任何来源”_Mac安装未签名应用的
- Go 中 defer 在 goroutine 内部
- Win11怎么更改系统语言为中文_Windows1
- php订单日志怎么记录评价_php记录订单评价日志
- Win11怎么设置默认浏览器Chrome_Wind


QQ客服