0

0

css:first-child选择器不生效怎么办_检查父元素结构并正确使用:first-child

P粉602998670

P粉602998670

发布时间:2025-12-24 13:42:08

|

388人浏览过

|

来源于php中文网

原创

:first-child不生效的主因是目标元素并非父元素的第一个子节点,因空白文本或注释节点被计入DOM;应检查开发者工具确认结构,或改用:first-of-type、修正空格、排查优先级与JS动态插入影响。

css:first-child选择器不生效怎么办_检查父元素结构并正确使用:first-child

:first-child 选择器不生效,最常见的原因是它匹配的不是你“以为的第一个子元素”,而是严格按 HTML 结构中**父元素下的第一个子节点**来判断的。它不看元素类型,只看 DOM 树中的位置顺序。

确认目标元素确实是父元素的第一个子元素

比如以下 HTML:

  • 首页
  • 关于

如果

    开头有换行、空格或注释,浏览器会把它们解析为文本节点(或注释节点),那么
  • 就不是 :first-child 了。

    • 用浏览器开发者工具(F12)展开父元素,查看其子节点列表,确认第一个是否真是你要选的元素
    • 若存在空白文本节点,可删掉多余换行/空格,或改用 :first-of-type

    区分 :first-child 和 :first-of-type

    :first-child 要求元素既是第一个子节点,又要是指定标签;:first-of-type 只要求是该类型中第一个出现的,对前面的其他标签不敏感。

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

    BibiGPT-哔哔终结者
    BibiGPT-哔哔终结者

    B站视频总结器-一键总结 音视频内容

    下载
    • 想选

      中第一个 ?用 p em:first-of-type
    • 想选整个列表里第一个
    • ,且它必须是
        下第一个子元素?才用 ul li:first-child
      • 多数场景下,:first-of-type 更符合直觉,也更稳定

      检查 CSS 优先级和拼写错误

      即使结构正确,样式也可能被覆盖或写错:

      • 确认选择器拼写是 :first-child(不是 :firstchild::first-child —— 伪类用单冒号)
      • 检查是否有更高级别的规则(如 class、id 或内联样式)覆盖了你的 :first-child 样式
      • 在开发者工具中看该样式是否被划掉,被划掉说明被覆盖,点击右侧可追踪来源

      注意动态内容或 JS 插入的影响

      如果元素是 JS 动态插入的,要确保 CSS 规则在插入前已加载,且插入时结构符合 :first-child 的条件。

      • 例如用 innerHTML 插入多个
      • ,但没包裹在
          内,或插入后第一个子节点不是目标元素
        • 可改用 JS 直接添加 class(如 el.classList.add('first')),再用 .first 控制样式,更可控
      • 热门AI工具

        更多
        DeepSeek
        DeepSeek

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

        豆包大模型
        豆包大模型

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

        通义千问
        通义千问

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

        腾讯元宝
        腾讯元宝

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

        文心一言
        文心一言

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

        讯飞写作
        讯飞写作

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

        即梦AI
        即梦AI

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

        ChatGPT
        ChatGPT

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

        相关专题

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

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

        469

        2024.01.03

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

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

        13

        2025.12.06

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

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

        513

        2023.06.20

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

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

        244

        2023.07.28

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

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

        298

        2023.08.03

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

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

        5306

        2023.08.17

        js删除节点的方法
        js删除节点的方法

        js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

        481

        2023.09.01

        js截取字符串的方法
        js截取字符串的方法

        js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

        212

        2023.09.04

        俄罗斯Yandex引擎入口
        俄罗斯Yandex引擎入口

        2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

        158

        2026.01.28

        热门下载

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

        精品课程

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

        共14课时 | 0.8万人学习

        Bootstrap 5教程
        Bootstrap 5教程

        共46课时 | 3万人学习

        CSS教程
        CSS教程

        共754课时 | 24.6万人学习

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

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