我在表格和网络应用程序的其他部分使用了checkbox
。
此复选框位于DIV
内,因此外观更精致。
这是HTML
:
<div class="checkbox checkbox-success checkbox-single">
<input type="checkbox"><label></label>
</div>
我已经检测到当我点击复选框的中心时它可以正常工作,但如果我在左上角,右上角或左下角检查过它就不起作用。
然后我检查Google chrome
中的元素,并在选择input
元素时找到了。
这就是为什么它不起作用,因为输入元素不是以div为中心。
我使用的是Bootstrap 3。
以下是我在选择CSS
元素时在Google Chrome检查器中看到的input
。
以下是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
这是打破我的头脑,任何线索?
答案 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
空格的内容。