css如何选中未选中的复选框_通过not checked伪类

发布时间 - 2026-01-07 00:00:00    点击率:
要选中未被勾选的复选框,应使用 :not(:checked) 伪类控制关联元素(如 label 或其子元素)样式,而非直接设置复选框本身;推荐默认设未选中态样式,再用 :checked 覆盖已选中状态,以提升兼容性与可维护性。

要选中未被勾选的复选框,可以使用 :not(:checked) 伪类组合,但需注意:该选择器本身不能直接作用于 元素来设置其样式(因为复选框原生控件无法通过 CSS 设置“未选中时的外观”),真正有效的是用它来控制**关联元素**(比如旁边的标签、父容器或后续兄弟元素)的样式。

正确用法:控制关联标签或容器

常见做法是将 与复选框显式关联(用 for 属性或包裹结构),再用 :not(:checked) 选中未勾选状态下的 label 或其子元素:

  • HTML 推荐结构(隐式关联):
  • CSS 示例(给未选中时的 label 添加灰色文字):
    label input[type="checkbox"]:not(:checked) + span { color: #999; }
    或更稳妥地(利用 label 包裹):
    label input[type="checkbox"]:not(:checked) ~ span { opacity: 0.7; }

替代方案:用 :checked 反向控制更可靠

实际开发中,:not(:checked) 在部分旧浏览器(如 IE)支持不完整,且逻辑易出错。更推荐写法是默认样式设为“未选中态”,再用 :checked 覆盖已选中状态:

  • 默认设置 label 样式(即未选中时):
    label { color: #666; font-weight: normal; }
  • 仅当勾选后才改变:
    input[type="checkbox"]:checked + label { color: #007bff; font-weight: bold; }

注意事项

  • :not(:checked) 只对 有效,对其他类型无效
  • 不能用它修改复选框本身的方框(如背景、边框),因原生 checkbox 的 UI 由系统渲染,CSS 可控性极低;如需自定义外观,应隐藏原生控件,用 ::before/::after 模拟
  • 确保 HTML 结构满足 CSS 选择器的层级关系(如相邻兄弟 +、通用兄弟 ~ 或父子关系)


# css  # html  # 浏览器  # for  # checkbox  # 选择器  # 伪类  # input  # ui  # 复选框  # 勾选  # 再用  # 用它  # 未被  # 其子  # 的是  # 设为  # 自定义 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 利用JavaScript实现拖拽改变元素大小  Laravel集合Collection怎么用_Laravel集合常用函数详解  laravel怎么为API路由添加签名中间件保护_laravel API路由签名中间件保护方法  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  零基础网站服务器架设实战:轻量应用与域名解析配置指南  作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】  创业网站制作流程,创业网站可靠吗?  如何在阿里云虚拟服务器快速搭建网站?  如何用VPS主机快速搭建个人网站?  极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?  浅谈javascript alert和confirm的美化  Laravel Docker环境搭建教程_Laravel Sail使用指南  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  利用 Google AI 进行 YouTube 视频 SEO 描述优化  Linux系统命令中tree命令详解  微信小程序 wx.uploadFile无法上传解决办法  北京网站制作公司哪家好一点,北京租房网站有哪些?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  Python高阶函数应用_函数作为参数说明【指导】  iOS中将个别页面强制横屏其他页面竖屏  js实现获取鼠标当前的位置  Laravel如何实现API速率限制?(Rate Limiting教程)  EditPlus 正则表达式 实战(3)  如何快速生成ASP一键建站模板并优化安全性?  使用C语言编写圣诞表白程序  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  南京网站制作费用,南京远驱官方网站?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  在Oracle关闭情况下如何修改spfile的参数  如何快速查询网站的真实建站时间?  Android自定义控件实现温度旋转按钮效果  Android 常见的图片加载框架详细介绍  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何自定义建站之星模板颜色并下载新样式?  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  如何在云服务器上快速搭建个人网站?  html5怎么画眼睛_HT5用Canvas或SVG画眼球瞳孔加JS控制动态【绘制】  IOS倒计时设置UIButton标题title的抖动问题  如何在IIS服务器上快速部署高效网站?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  三星网站视频制作教程下载,三星w23网页如何全屏?  java中使用zxing批量生成二维码立牌  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  如何在建站之星网店版论坛获取技术支持?