选中时更改复选框背景颜色

Low*_*rux 6 html css checkbox

我正在使用 css3 更改所有复选框的外观和感觉,但我正在尝试找到一种更好的方法来实现选中的属性(选中时,复选框必须只填充纯色),我真的不知道如果使用填充来完成这是最佳实践,因为在使用不同的浏览器时我会得到不同的结果。一些建议将不胜感激。

这是我想要完成的:

未选中的复选框:

在此处输入图片说明

勾选复选框:

在此处输入图片说明

以下是 CSS 和 HTML:

.checkbox {
  margin: 0 0 1em 2em;
}
.checkbox .tag {
  color: #595959;
  display: block;
  float: left;
  font-weight: bold;
  position: relative;
  width: 120px;
}
.checkbox label {
  display: inline;
}
.checkbox .input-assumpte {
  display: none;
}
.input-assumpte + label {
  -webkit-appearance: none;
  background-color: #fafafa;
  border: 1px solid #cacece;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
  padding: 9px;
  display: inline-block;
  position: relative;
}
.input-assumpte:checked + label:after {
  background-color: #595959;
  color: #595959;
  content: '\2714';
  font-size: 10px;
  left: 0px;
  padding: 2px 8px 2px 2px;
  position: absolute;
  top: 0px;
}
Run Code Online (Sandbox Code Playgroud)
<div class="checkbox">
  <div class="tag">Confidencial</div>
  <input type="checkbox" class="input-assumpte" id="input-confidencial">
  <label for="input-confidencial"></label>
</div>
Run Code Online (Sandbox Code Playgroud)

请注意,我必须在复选框选中状态中包含一个字符,以便能够添加填充以使用背景颜色填充整个复选框,正如我之前所说,我真的试图找到一种更好的方法来做到这一点。

这是 JSFiddel:http : //jsfiddle.net/Lter​​04p8/

Jac*_*cob 5

添加正确的内容background-colorwidth: 100%; height: 100%; 然后将“overflow:hidden”添加到父级 ( .input-assumpte) 并删除复选框标记。

请注意,它content: "";仍然存在,没有它:after:before将不会显示。

.checkbox {
  margin: 0 0 1em 2em;
}
.checkbox .tag {
  color: #595959;
  display: block;
  float: left;
  font-weight: bold;
  position: relative;
  width: 120px;
}
.checkbox label {
  display: inline;
}
.checkbox .input-assumpte {
  display: none;
}
.input-assumpte + label {
  -webkit-appearance: none;
  background-color: #fafafa;
  border: 1px solid #cacece;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
  padding: 9px;
  display: inline-block;
  position: relative;
  overflow: hidden;
}
.input-assumpte:checked + label:after {
  width: 100%;
  height: 100%;
  content: "";
  background-color: #008FD5;
  left: 0px;
  position: absolute;
  top: 0px;
}
Run Code Online (Sandbox Code Playgroud)
<div class="checkbox">
  <div class="tag">Confidencial</div>
  <input type="checkbox" class="input-assumpte" id="input-confidencial">
  <label for="input-confidencial"></label>
</div>
Run Code Online (Sandbox Code Playgroud)


con*_*exo 4

这里不需要填充。只需使用display: inline-block;on :after、应用widthheight,并应用平滑过渡。而且你也不需要额外的<div>

.checkbox {
  margin: 0 0 1em 2em;
}
.checkbox .tag {
  color: #595959;
  display: block;
  float: left;
  font-weight: bold;
  position: relative;
  width: 120px;
}
.checkbox label {
  display: inline;
}
.checkbox .input-assumpte {
  display: none;
}
.input-assumpte + label:after {
  background-color: #fafafa;
  border: 1px solid #cacece;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0px -15px 10px -12px rgba(0, 0, 0, 0.05);
  display: inline-block;
  transition-duration: 0.3s;
  width: 16px;
  height: 16px;
  content: '';
  margin-left: 10px;
}
.input-assumpte:checked + label:after {
  background-color: #595959;
}
Run Code Online (Sandbox Code Playgroud)
<div class="checkbox">
  <input type="checkbox" class="input-assumpte" id="input-confidencial" />
  <label for="input-confidencial">Confidencial</label>
</div>
Run Code Online (Sandbox Code Playgroud)