当前位置:首页 > 前端技术 > 纯 CSS 解决自定义 CheckBox 背景颜色问题

纯 CSS 解决自定义 CheckBox 背景颜色问题

CodePen

需要使用色 #ec6337(当然可以是任意颜色),解决问题:记住密码定制 CheckBox,解释全在注释里

未选中

选中

主要使用到 ::before 或 ::after 伪类处理,伪装成内部的那个勾

  • html
<label>
  <input type="checkbox" /> // 注意嵌在 label 里面
  记住密码
  <div class="show-box" /> // 注意嵌在 label 里面
</label>
  • CSS(LESS)
label {
  position: relative;
  cursor: pointer;

  input {
    cursor: pointer;
  }

  input:checked   .show-box {
    background: #ec6337;
  }

  .show-box {
    position: absolute;
    top: 0;
    left: 0;
    width: 16px;
    height: 16px;
    border-radius: 2px;
    border: 1px solid #d8d8d8;
    background: white; // 这里取个巧,与下面颜色一样而已

    &:before { // 使用了 absolute 所以无所谓是 before 还是 after
      content: ''; // 空白内容占位,当做盒模型处理,见下面
      position: absolute;
      top: 2px;
      left: 6px;
      width: 3px; // 勾的短边
      height: 8px; // 勾的长边
      border: solid white; // 勾的颜色
      border-width: 0 2px 2px 0; // 勾的宽度
      transform: rotate(45deg); // 定制宽高加上旋转可以伪装内部的白色勾
    }
  }

CodePen

作者:普通网友
来源链接:https://blog.csdn.net/qq_37555524/article/details/100178838


版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/front/69131.html

标签: css
分享给朋友: