CSS伪类通过状态选择元素,如:hover响应悬停、:focus处理焦点、:checked识别选中表单、:nth-child和:nth-of-type按位置筛选、:disabled/:enabled控制启用状态、:valid/:invalid实现输入验证,提升交互与可访问性。

CSS 伪类用于选择处于特定状态的元素,而不是基于元素的内容或标签名。它们以冒号(:)开头,可以用来响应用户交互、元素在文档中的位置或表单的状态等。
:hover — 鼠标悬停时的样式
当用户将鼠标指针悬停在元素上时应用样式。
常见用途:按钮变色:让按钮在悬停时改变背景色 下拉菜单触发:配合其他结构实现导航菜单展开
示例:
Reclaim.ai
为优先事项创建完美的时间表
90 查看详情
button:hover { background-color: #0056b3; }
:focus — 元素获得焦点
适用于表单元素(如 input、textarea)或可聚焦元素(带 tabindex 的元素)被点击或通过 Tab 键选中时。
立即学习“前端免费学习笔记(深入)”;
实用场景:输入框高亮边框,提示用户当前正在输入 提升可访问性,让键盘操作更清晰
示例:
input:focus { border-color: #007bff; outline: none; }
:checked — 单选/复选框被选中
匹配被选中的 或 。
可用于:自定义复选框样式 结合 label 实现隐藏控件的视觉反馈
示例:
input[type=”checkbox”]:checked + label { color: green; }
:nth-child(n) 和 :nth-of-type(n) — 按位置选择
根据元素在其父容器中的位置选择子元素。
区别说明::nth-child(2):选择父元素下的第二个子元素,且该元素必须匹配前面的选择器 :nth-of-type(2):选择同类型标签中的第二个(比如第二个 p 标签)
示例:
li:nth-child(odd) { background: #f0f0f0; }p:nth-of-type(2) { font-weight: bold; }
:disabled / :enabled — 表单元素状态
分别匹配被禁用或启用的表单控件。
典型应用:灰化不可用按钮 调整输入框透明度以表示不可编辑
示例:
input:disabled { opacity: 0.6; }
:valid / :invalid — 表单验证状态
根据 HTML5 验证规则判断输入内容是否合法。
适合:实时反馈用户输入格式(如邮箱、必填项) 配合 :focus 使用增强体验
示例:
input:valid { border-left: 4px solid green; }input:invalid { border-left: 4px solid red; }
基本上就这些常用伪类。掌握它们能让你在不改动 HTML 结构的前提下,灵活控制不同状态下的样式表现,尤其适合做交互反馈和动态界面优化。
以上就是如何用css伪类选择特定状态元素的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/996991.html
微信扫一扫
支付宝扫一扫