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

CSS 伪类用于选择处于特定状态的元素,而不是基于元素的内容或标签名。它们以冒号(:)开头,可以用来响应用户交互、元素在文档中的位置或表单的状态等。
:hover — 鼠标悬停时的样式
当用户将鼠标指针悬停在元素上时应用样式。
常见用途:- 按钮变色:让按钮在悬停时改变背景色
- 下拉菜单触发:配合其他结构实现导航菜单展开
示例:
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 结构的前提下,灵活控制不同状态下的样式表现,尤其适合做交互反馈和动态界面优化。










