属性选择器^=、$=和=在CSS中用于根据元素的属性值进行匹配,它们的区别如下:1.[attr=value](等于)作用:选择具有指定属性且属性值完全等于给定值的元素。示例:a[href="https://example.com"]{color:red;}只有href属性完全等于"https://example.com"的<a>标签会被选中。2.[attr^=value](以...开头
时间:2026-01-30 12:31:40 441浏览 收藏
欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《属性选择器^=、$=、=的区别是什么?》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!
属性选择器[attr^="value"]匹配属性值严格以指定字符串开头(区分大小写、不可有前置空格);[attr$="value"]匹配严格以指定字符串结尾;[attr="value"]表示完全相等(含空格大小写),非包含匹配;子字符串匹配应使用[attr*="value"]。

属性选择器 [attr^="value"] 匹配开头
这个选择器检查元素的 attr 属性值是否**严格以指定字符串开头**,区分大小写,且必须是完整属性值的起始位置。
常见误用:以为能匹配单词边界或子字符串,比如 [class^="btn"] 会选中 class="btn-primary",但不会选中 class="my-btn"(因为不是“以 btn 开头”,而是以 my- 开头)。
实操建议:
- 适合用于统一前缀的自定义属性,如
data-api-url^="https://api.example.com" - 注意空格影响:如果属性值有前置空格(如
class=" btn-primary"),^=就不匹配 —— HTML 解析后空格属于值的一部分 - 不能省略引号,
[attr^=value]在某些浏览器中可能解析失败,始终写成[attr^="value"]
属性选择器 [attr$="value"] 匹配结尾
它要求属性值**严格以指定字符串结尾**,同样区分大小写、不忽略首尾空格,且必须是整个属性值的末尾。
典型场景:筛选特定后缀的资源链接或文件类型:
a[href$=".pdf"]可匹配href="report.pdf",但不匹配href="report.pdf?ver=1"[src$="/logo.png"]要求路径最后一段**正好是 logo.png**,不能带查询参数或 hash- 对 class 属性慎用:因为
class="icon icon--large"的属性值结尾是--large,不是large;若想匹配含 large 的 class,该用*=或 JS 处理
属性选择器 [attr="value"] 是完全相等,不是包含
标题里说的 “= 匹配包含内容” 是常见误解。[attr="value"] **只匹配属性值与字符串完全一致的情况**(包括空格、大小写、顺序),和 JavaScript 的 === 类似。
例如:
[type="submit"]匹配,但不匹配(多了空格)[class="btn"]不会匹配class="btn primary",哪怕它“包含 btn” —— 因为整个值是"btn primary",不等于"btn"- 若真要匹配“包含某个单词”的 class,应使用
[class~="btn"](波浪号表示空格分隔的单词匹配)
别把 *= 和 = 搞混了
真正做“包含子字符串”匹配的是 [attr*="value"],不是 =。这是最容易踩的坑。
对比示例:
[title*="error"]→ 匹配title="Network error occurred"✔️[title="error"]→ 只匹配title="error",其他都不行 ❌[title~="error"]→ 匹配title="system error warning"(空格分隔)✔️,但不匹配title="error-code"❌
性能上,*= 和 ^=/$= 都比 = 慢,尤其在深层 DOM 中大量使用时;若只需精确匹配,优先用 =。
浏览器兼容性不是问题 —— 这些选择器在 IE7+ 就已支持,但注意:CSS 层叠顺序仍受特异性规则约束,[attr="v"] 和 .cls 特异性相同,谁在后面谁生效。
以上就是《属性选择器^=、$=和=在CSS中用于根据元素的属性值进行匹配,它们的区别如下:1.[attr=value](等于)作用:选择具有指定属性且属性值完全等于给定值的元素。示例:a[href="https://example.com"]{color:red;}只有href属性完全等于"https://example.com"的标签会被选中。2.[attr^=value](以...开头)作用:选择具有指定属性且属性值以指定值开头的元素。示例:a[href^="https"]{color:blue;}所有href属性以"https"开头的标签都会被选中,如"https://example.com"或"https://www.example.com"。3.[attr$=value](以...结尾)作用:选择具有指定属性且属性值以指定值结尾的元素。示例:a[href$=".pdf"]{color:green》的详细内容,更多关于的资料请关注golang学习网公众号!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
331 收藏
-
439 收藏
-
456 收藏
-
347 收藏
-
250 收藏
-
355 收藏
-
220 收藏
-
247 收藏
-
427 收藏
-
431 收藏
-
471 收藏
-
111 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习