0

0

css :nth of type 使用场景_同类型元素选择方法

P粉602998670

P粉602998670

发布时间:2026-01-07 09:15:33

|

616人浏览过

|

来源于php中文网

原创

应使用:nth-of-type()当需选中某标签类型第n个元素且其前存在其他类型标签时;它仅按同名标签计数,忽略伪元素、文本节点及属性,而:nth-child()则按所有子元素顺序计数。

css :nth of type 使用场景_同类型元素选择方法

什么时候该用 :nth-of-type() 而不是 :nth-child()

当你要选中「某类标签的第 N 个」,且它前面可能混着其他标签时,:nth-of-type() 才是正确选择。比如父容器里有 <p></p><div>、<code><p></p><span></span><p></p>,你想让第 2 个 <p></p> 变红——用 :nth-child(3) 会错(它是第 3 个子元素),但 p:nth-of-type(2) 精准命中。

:nth-of-type(n) 的常见写法和陷阱

它的参数规则和 :nth-child() 完全一致,但计数范围只限「同标签名」。容易出错的地方:

  • div:nth-of-type(2n) 选的是所有 <div> 中偶数位置的(第 2、4、6…个 <code><div>),不是页面中所有偶数子元素<li>它不认 class 或属性,<code>div.red:nth-of-type(1)div:nth-of-type(1) 效果一样——只要第一个 <div> 存在,就匹配,不管它有没有 <code>class="red"
  • 伪元素(如 ::before)和文本节点完全不影响它的计数,只看开始标签名
  • 和 JavaScript 的 querySelectorAll() 行为对比

    CSS 的 :nth-of-type() 是渲染时静态匹配,而 JS 的 document.querySelectorAll('p:nth-of-type(2)') 也遵循同样逻辑——但它依赖浏览器当前 DOM 结构。注意:

    Q.AI视频生成工具
    Q.AI视频生成工具

    支持一分钟生成专业级短视频,多种生成方式,AI视频脚本,在线云编辑,画面自由替换,热门配音媲美真人音色,更多强大功能尽在QAI

    下载
    • 动态插入新 <p></p> 后,原有元素的序号可能变化,样式自动重算,但 JS 获取的 NodeList 不会自动更新
    • document.querySelector('p:nth-of-type(1)') 返回的是第一个 <p></p> 元素,不是第一个子元素中是 <p></p> 的那个(这点常被误读)
    • 如果想用 JS 模拟“取第 N 个某类型元素”,更稳妥的是:
      Array.from(document.querySelectorAll('p')).at(n - 1)
      ,避免被中间混入的其他标签干扰

    替代方案:什么时候不该用 :nth-of-type()

    如果你的目标元素本身就有稳定 class、data 属性或结构位置(比如固定在某个容器第 3 层),直接加 class 或用更明确的选择器反而更可靠:

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

    • 需要选中「第 3 个子元素,且它必须是 <section></section>」→ 用 :nth-child(3 of section)(CSS Selectors Level 4,但目前仅 Safari/Chrome 119+ 支持,兼容性差)
    • 要选中「带 data-role="item" 的第 2 个元素」→ 写 [data-role="item"]:nth-of-type(2) 没用(:nth-of-type 不感知属性),应改用 [data-role="item"]:nth-child(2) 或加 class 控制
    • 复杂嵌套下反复调试不到预期效果?大概率是忽略了父级中隐藏的 <template></template>、注释节点或空格文本节点——它们不算 :nth-of-type 的计数对象,但会影响 :nth-child,这种差异恰恰是最容易漏查的点

相关文章

CSS如何让列表项在删除时平滑收缩

CSS如何实现网格项在容器内均匀分布_利用place-content:center简写属性css

CSS如何使用@import导入_在样式表顶部引入子级css文件

CSS如何使右浮动的按钮不改变HTML结构流_利用其特有的右移属性而不影响左侧元素的普通流

CSS粘性定位在列表标题中的应用_实现吸顶分类提示效果

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

上一篇:css绝对定位与相对定位的区别_如何选择合适的定位方式 下一篇:css需要快速生成多列结构怎么办_利用repeat函数简化列定义

作者最新文章

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1057

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

837

2023.11.06

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

870

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

30

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6177

2023.08.17

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

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

相关下载

更多

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.1万人学习

最新文章

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

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