带有DIV复选框的CSS,输入未与DIV中心对齐

时间:2016-12-25 17:44:12

标签: css checkbox twitter-bootstrap-3

我在表格和网络应用程序的其他部分使用了checkbox

此复选框位于DIV内,因此外观更精致。

enter image description here

这是HTML

中复选框的形式
<div class="checkbox checkbox-success checkbox-single">
   <input type="checkbox"><label></label>
</div>

我已经检测到当我点击复选框的中心时它可以正常工作,但如果我在左上角,右上角或左下角检查过它就不起作用。

然后我检查Google chrome中的元素,并在选择input元素时找到了。

enter image description here

这就是为什么它不起作用,因为输入元素不是以div为中心。

我使用的是Bootstrap 3。

以下是我在选择CSS元素时在Google Chrome检查器中看到的input

enter image description here

以下是CSS我认为应用于Style.css

.checkbox {
  padding-left: 20px;
}
.checkbox label {
  display: inline-block;
  padding-left: 5px;
  position: relative;
}
.checkbox label::before {
  -o-transition: 0.3s ease-in-out;
  -webkit-transition: 0.3s ease-in-out;
  background-color: #ffffff;
  border-radius: 3px;
  border: 1px solid #cccccc;
  content: "";
  display: inline-block;
  height: 17px;
  left: 0;
  margin-left: -20px;
  position: absolute;
  transition: 0.3s ease-in-out;
  width: 17px;
  outline: none !important;
}
.checkbox input[type="checkbox"] {
  cursor: pointer;
  opacity: 0;
  z-index: 1;
  outline: none !important;
}
.checkbox label::after {
  color: #555555;
  display: inline-block;
  font-size: 11px;
  height: 16px;
  left: 0;
  margin-left: -20px;
  padding-left: 3px;
  padding-top: 1px;
  position: absolute;
  top: 0;
  width: 16px;
}
.checkbox.checkbox-single label {
  height: 17px;
}
.checkbox-success input[type="checkbox"]:checked + label::before {
  background-color: #01ba9a;
  border-color: #01ba9a;
}
.checkbox-success input[type="checkbox"]:checked + label::after {
  color: #ffffff;
}

以下是CodePen示例,请勿显示相同的确切位置,但您会看到输入未居中对齐。

http://codepen.io/anon/pen/Jbqapo

  

这是打破我的头脑,任何线索?

1 个答案:

答案 0 :(得分:0)

将以下div添加到.checkbox input[type="checkbox"]选择器以覆盖不带!important s的引导程序,然后添加以下CSS属性:

div.checkbox input[type="checkbox"] {
  /* add these */
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 16px;
  margin: 0;
}

以下代码段:

.checkbox {
  padding-left: 20px;
}
.checkbox label {
  display: inline-block;
  padding-left: 5px;
  position: relative;
}
.checkbox label::before {
  -o-transition: 0.3s ease-in-out;
  -webkit-transition: 0.3s ease-in-out;
  background-color: #ffffff;
  border-radius: 3px;
  border: 1px solid #cccccc;
  content: "";
  display: inline-block;
  height: 17px;
  left: 0;
  margin-left: -20px;
  position: absolute;
  transition: 0.3s ease-in-out;
  width: 17px;
  outline: none !important;
}
div.checkbox input[type="checkbox"] {
  cursor: pointer;
  opacity: 0;
  z-index: 1;
  outline: none !important;

  /* add these */
  position: absolute;
  top: 0;
  left: 0;
  width: 16px;
  height: 16px;
  margin: 0;
}
.checkbox label::after {
  color: #555555;
  display: inline-block;
  font-size: 11px;
  height: 16px;
  left: 0;
  margin-left: -20px;
  padding-left: 3px;
  padding-top: 1px;
  position: absolute;
  top: 0;
  width: 16px;
}
.checkbox.checkbox-single label {
  height: 17px;
}
.checkbox-success input[type="checkbox"]:checked + label::before {
  background-color: #01ba9a;
  border-color: #01ba9a;
}
.checkbox-success input[type="checkbox"]:checked + label::after {
  color: #ffffff;
}
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet"/>
<div class="checkbox checkbox-success checkbox-single">
  <input type="checkbox">
  <label></label>
</div>

这样它将涵盖所有包含div空格的内容。

enter image description here