:checked伪类用于选中状态的复选框或单选按钮,可改变其样式或联动其他元素;通过accent-color可修改默认颜色,结合label与隐藏input能自定义外观,利用兄弟选择器可实现无JS的折叠菜单等交互效果。

当处理复选框的样式时,:checked 伪类选择器非常有用。它能选中处于“选中”状态的单选按钮或复选框,让你可以基于用户交互动态改变样式。
基本用法
:checked 可用于 input[type="checkbox"] 或 input[type="radio"] 元素,匹配当前被选中的控件。
例如:
input[type="checkbox"]:checked {
accent-color: #4caf50;
}
这段代码会将选中的复选框颜色设为绿色。现代浏览器默认支持 accent-color 属性来简单修改复选框颜色。
立即学习“前端免费学习笔记(深入)”;
自定义复选框样式
如果想完全替换原生复选框外观,通常结合 label 和隐藏的 input 使用。
技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作
- 隐藏原始复选框(使用 opacity: 0 或 display: none)
- 用 label 模拟视觉样式
- 通过 :checked 控制 label 的显示效果
示例代码:
.custom-checkbox {
display: none;
}
.checkbox-label {
position: relative;
padding-left: 30px;
cursor: pointer;
}
.checkbox-label::before {
content: '';
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 18px;
height: 18px;
border: 2px solid #999;
background-color: white;
}
.checkbox-label::after {
content: '✔';
position: absolute;
left: 4px;
top: 50%;
transform: translateY(-50%);
font-size: 12px;
color: white;
opacity: 0;
}
.custom-checkbox:checked + .checkbox-label::after {
opacity: 1;
}
.custom-checkbox:checked + .checkbox-label::before {
background-color: #4caf50;
border-color: #4caf50;
}
配合其他元素联动
:checked 不仅能改变自身样式,还能控制其他元素的显示,比如制作无 JS 的折叠菜单或开关组件。
利用兄弟选择器(+ 或 ~),可以实现选中后展开内容:
.panel {
display: none;
}
.toggle:checked ~ .panel {
display: block;
}
基本上就这些。使用 :checked 配合 label 和 CSS 生成内容,能做出美观且可访问的复选框样式,无需 JavaScript。关键是结构清晰,确保可点击区域足够大,提升用户体验。









