0

0

属性选择器如何选择包含特定值的元素_利用方括号匹配精确条件

P粉602998670

P粉602998670

发布时间:2026-03-03 11:48:11

|

204人浏览过

|

来源于php中文网

原创

属性值完全匹配用[attr="value"],要求一字不差、大小写与空格均敏感;[attr~="val"]用于空格分隔的单词匹配(如class);[attr*="sub"]和[attr^="pre"]为子串与前缀模糊匹配;引号必需,标准模式下大小写敏感。

属性选择器如何选择包含特定值的元素_利用方括号匹配精确条件

属性值完全匹配用 [attr="value"]

这是最直接的“精确等于”写法,浏览器只选中 attr 属性值**一字不差等于** "value" 的元素。注意:大小写敏感、空格敏感、不可有前后空白。

常见错误是把带空格的 class 当成整体匹配:.nav-item 元素写成 class="nav-item active",若用 [class="nav-item"] 就完全不生效——因为实际值是 "nav-item active",不是 "nav-item"

适用场景:自定义属性(如 data-status)、布尔型属性(如 disabled[disabled="disabled"])或确保值绝对干净的场景。

[attr~="val"] 匹配空格分隔的单词

当属性值是空格分隔的多个词(典型如 class),用波浪号 ~ 表示“包含某个单词”。它会把值按空格切开,再逐个比对。

XiaoHu.AI
XiaoHu.AI

由小互建立的一个AI资讯、教程、课程、工具以及开源项目案例的平台。

下载
  • [class~="btn"] 能命中 class="btn primary"class="btn"class="large btn small"
  • 但不会匹配 class="btn-primary"(连字符不算分隔)或 class="button"(拼写不同)
  • 注意:HTML 规范要求 class 值必须以空格分隔,所以这个选择器对 class 是安全的;但对自定义属性,得确保你控制了它的格式

[attr*="sub"][attr^="pre"] 是子串/前缀匹配

这两个不是“精确条件”,但常被误当作精确用。它们属于模糊匹配:

  • [href*="github"] 匹配所有 href 中含 "github" 的链接,包括 https://github.comhttps://my-github-backup.net
  • [data-id^="user-"] 匹配 data-id="user-123",但也会匹配 data-id="user-123-admin"
  • 它们不区分单词边界,也不做规范化处理(比如忽略大小写需额外加 i 标志,但仅部分浏览器支持 [attr^="val" i]

容易被忽略的细节:引号、大小写与 HTML 模式

属性选择器中的值必须加引号(单或双均可),否则遇到特殊字符(如 .-、空格)会解析失败。例如 [data-role=main-nav] 在某些解析器下可能报错,而 [data-role="main-nav"] 总是安全的。

HTML 文档在 quirks 模式下,属性值比较可能不区分大小写;但在标准模式()下,<code>[lang="EN"] 不会匹配 lang="en"。如果需要大小写无关,目前没原生 CSS 方案,得靠 JS 或预处理时统一标准化值。

真正“包含特定值”的精确需求,往往要结合语义和属性设计:优先用 data- 属性存结构化值,避免把多值塞进一个属性里硬匹配。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

747

2024.01.03

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

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

24

2025.12.06

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

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

530

2023.06.20

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

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

514

2023.07.28

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

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

678

2023.08.03

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

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

5910

2023.08.17

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

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

492

2023.09.01

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

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

219

2023.09.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

0

2026.03.03

热门下载

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

精品课程

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

共137课时 | 12.8万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.9万人学习

Vue.js 微实战--十天技能课堂
Vue.js 微实战--十天技能课堂

共18课时 | 1.2万人学习

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

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