0

0

css 新手最容易写错的选择器有哪些_避免混用 id 与 class

P粉602998670

P粉602998670

发布时间:2026-01-13 08:53:30

|

797人浏览过

|

来源于php中文网

原创

class 和 id 选择器必须严格对应:. 对应 class 属性,# 对应 id 属性;多 class 元素 CSS 中需连写无空格(如 .a.b);id 仅用于 JS 或锚点,样式应统一用 class。

css 新手最容易写错的选择器有哪些_避免混用 id 与 class

class 和 id 选择器写反了,浏览器不会报错但样式不生效

这是新手最常踩的坑:把 class="header" 写成 id="header",却在 CSS 里用 .header 去选;或者反过来,HTML 用了 class="btn-primary",CSS 却写成 #btn-primary。浏览器完全不报错,只是默默忽略匹配失败的选择器。

关键判断点:. 开头一定对应 class 属性,# 开头一定对应 id 属性,二者不能交叉使用。

  • 检查 HTML 中的属性名是 class 还是 id
  • 检查 CSS 选择器开头是 . 还是 #
  • 用浏览器开发者工具(F12)看元素是否被该 CSS 规则“击中”——没被列在“Styles”面板里,大概率就是选错了

误以为 class 可以用 # 选,或 id 可以用 . 选

有人觉得“反正都唯一”,就用 #my-class 去选 class="my-class",或者用 .my-id 去选 id="my-id"。这是无效的——CSS 选择器语法严格区分语义:# 只认 id 属性值,. 只认 class 属性值,和内容是否重复、是否唯一无关。

哪怕你只用了一次 class="logo",也必须写成 .logo;哪怕你给某个元素加了 id="wrapper",也不能靠 .wrapper 拿到它。

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

  • #logo → 只匹配 id="logo"
  • .logo → 只匹配 class="logo"(可多个元素)
  • [id="logo"][class="logo"]属性选择器,能绕过语法限制,但没必要,且性能略差

混淆 class 多值写法与空格分隔的后代选择器

HTML 中 class="btn btn-primary disabled" 是合法的,但新手常误写成 CSS 里的 .btn .btn-primary .disabled(带空格),结果变成“找 .btn 里面的 .btn-primary 里面的 .disabled”,而不是“同时有这三个 class 的元素”。

MaxAI
MaxAI

MaxAI.me是一款功能强大的浏览器AI插件,集成了多种AI模型。

下载

要选同时具备多个 class 的元素,必须连写无空格:.btn.btn-primary.disabled

.btn.btn-primary.disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
  • 空格 = 后代选择器(层级关系)
  • 紧挨着的点 = 同时满足多个 class(逻辑与)
  • 多 class 元素在 HTML 中用空格分隔,在 CSS 中用连续点连接

用 id 当作样式钩子,导致难以复用和维护

虽然 #nav-bar 能生效,但 id 在页面中必须唯一,且优先级远高于 class(#id 的 specificity 是 100,.class 是 10),容易引发样式覆盖冲突。新手常为每个按钮、标题都配一个 id,结果后期改一个样式要满页找 id 修改。

正确做法:id 仅用于 JS 锚点、getElementById 或 ARIA 关联(如 aria-labelledby),纯样式一律用 class。

  • 需要复用?→ 用 class
  • 需要 JS 精准控制单个元素?→ 用 id,但别在 CSS 里依赖它做样式
  • 想提高 specificity?用多个 class(如 .btn.btn--large.btn--primary),别靠 #

真正难的不是记住 .#区别,而是习惯性地把语义和用途分开:id 是“这个东西叫什么名字”,class 是“这个东西属于哪一类”。混用一次不报错,混用十次就难定位。

相关专题

更多
css
css

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

509

2023.06.15

css居中
css居中

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

262

2023.07.27

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

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

752

2023.07.28

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

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

537

2023.08.01

css字体颜色
css字体颜色

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

757

2023.08.10

什么是css
什么是css

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

603

2023.08.10

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

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

559

2023.08.21

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

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

389

2023.08.22

Java 项目构建与依赖管理(Maven / Gradle)
Java 项目构建与依赖管理(Maven / Gradle)

本专题系统讲解 Java 项目构建与依赖管理的完整体系,重点覆盖 Maven 与 Gradle 的核心概念、项目生命周期、依赖冲突解决、多模块项目管理、构建加速与版本发布规范。通过真实项目结构示例,帮助学习者掌握 从零搭建、维护到发布 Java 工程的标准化流程,提升在实际团队开发中的工程能力与协作效率。

10

2026.01.12

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 18.6万人学习

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

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