:disabled伪类仅匹配原生表单控件的disabled属性,不支持div等非表单元素或aria-disabled;需用class模拟非表单禁用,并配合tabindex="-1"和aria-disabled="true"保障可访问性。

disabled 属性的 CSS 选择器怎么写
直接用 :disabled 伪类即可匹配原生表单控件(、、、)上设置了 disabled 属性的元素。它只响应 HTML 层面的 disabled 属性,不识别 aria-disabled="true" 或 class 模拟禁用状态。
常见错误是试图用 [disabled] 属性选择器替代 —— 虽然能选中,但语义和可访问性支持远不如 :disabled,且部分浏览器对 [disabled] 的样式优先级处理不稳定。
button:disabled {
opacity: 0.5;
cursor: not-allowed;
background-color: #e0e0e0;
}
为什么 div 或自定义组件加 disabled 不生效
若需为非表单元素实现禁用样式,必须改用 class 控制: 立即学习“前端免费学习笔记(深入)”; 三者作用对象和触发条件完全不同: 混淆使用会导致样式错位。例如给 框架里常通过绑定 禁用状态的核心不是“看起来灰”,而是“行为和语义都断开”。样式只是表层反馈,属性、焦点、可访问性属性缺一不可。:disabled 是**仅限表单控件**的伪类, 这类写法在 HTML 中无效,浏览器会忽略该属性,:disabled 自然无法匹配。
class="is-disabled",再写 .is-disabled { ... }
tabindex="-1" 和 aria-disabled="true" 保证可访问性
:disabled 与 :read-only、:read-write 的区别
:disabled:只匹配带 disabled 属性的表单控件,完全不可交互、不提交、不获取焦点:read-only:匹配 readonly 属性或 contenteditable="false" 的元素,内容不可编辑但可聚焦、可选中、可复制:read-write:匹配可编辑状态(如 contenteditable="true" 或无 readonly/disabled 的 ),常用于高亮当前可编辑区域input[readonly] 写 :disabled 样式,实际不会生效。React/Vue 中动态控制
:disabled 样式要注意什么disabled prop 控制状态,但容易忽略两点:
false 时,HTML 属性可能被完全省略(如 React 中 不渲染 disabled 属性),此时 :disabled 不会触发 —— 必须确保禁用时属性存在,启用时移除disabled 属性,首屏样式可能与 JS 激活后不一致className 切换来模拟 :disabled 行为,否则键盘操作(如 Tab 键导航)仍会进入该元素










