登录
首页 >  文章 >  前端

CSS中:checked伪类用于选中被勾选的复选框,常用于自定义复选框样式。以下是具体应用方法:基本结构 使用 创建复选框,并通过 CSS 控制其样式。 隐藏默认复选框 通过 display: none

时间:2025-10-18 17:31:32 227浏览 收藏

CSS中的`:checked`伪类是一个强大的工具,尤其在自定义复选框和单选按钮样式时。本文详细介绍了`:checked`伪类的基本用法,它能让你轻松选中已勾选的复选框或单选按钮,并动态改变其样式。文章不仅讲解了如何使用`accent-color`属性快速修改默认颜色,还深入探讨了如何结合`

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

css伪类选择器:checked在复选框样式应用

当处理复选框的样式时,:checked 伪类选择器非常有用。它能选中处于“选中”状态的单选按钮或复选框,让你可以基于用户交互动态改变样式。

基本用法

:checked 可用于 input[type="checkbox"]input[type="radio"] 元素,匹配当前被选中的控件。

例如:

input[type="checkbox"]:checked {
  accent-color: #4caf50;
}

这段代码会将选中的复选框颜色设为绿色。现代浏览器默认支持 accent-color 属性来简单修改复选框颜色。

自定义复选框样式

如果想完全替换原生复选框外观,通常结合 label 和隐藏的 input 使用。

  • 隐藏原始复选框(使用 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。关键是结构清晰,确保可点击区域足够大,提升用户体验。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>