小提琴:http://jsfiddle.net/V98W8/
我有一个自定义复选框,它在Chrome中看起来很完美,但在Firefox或IE浏览器中显示完全破碎。
我尝试过添加自定义前缀和所有内容,但它似乎无法解决问题。
#milestone-table input[type="checkbox"] {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background-color: #fafafa;
border: 1px solid lightgrey;
border-radius: 26px;
-webkit-box-shadow: inset 0 0 0 1px lightgrey;
box-shadow: inset 0 0 0 1px lightgrey;
cursor: pointer;
height: 28px;
position: relative;
-webkit-transition: border .25s .15s, box-shadow .25s .3s, padding .25s;
-moz-transition: border .25s .15s, box-shadow .25s .3s, padding .25s;
-o-transition: border .25s .15s, box-shadow .25s .3s, padding .25s;
-ms-transition: border .25s .15s, box-shadow .25s .3s, padding .25s;
transition: border .25s .15s, box-shadow .25s .3s, padding .25s;
width: 54px;
vertical-align: top;
outline: none;
}
#milestone-table .controls input[type="checkbox"] {
margin-top: 10px;
}
#add-milestone {
position: relative;
top: 7px;
left: 90%;
}
#milestone-table {
margin-top: -20px;
}
#milestone-table input[type="checkbox"]:after {
background-color: white;
border: 1px solid lightgrey;
border-radius: 24px;
-webkit-box-shadow: inset 0 -3px 3px rgba(0, 0, 0, 0.025), 0 1px 4px rgba(0, 0, 0, 0.15), 0 4px 4px rgba(0, 0, 0, 0.1);
box-shadow: inset 0 -3px 3px rgba(0, 0, 0, 0.025), 0 1px 4px rgba(0, 0, 0, 0.15), 0 4px 4px rgba(0, 0, 0, 0.1);
content: '';
display: block;
height: 24px;
left: 0;
position: absolute;
right: 26px;
top: 0;
-webkit-transition: border .25s .15s, left .25s .1s, right .15s .175s;
-moz-transition: border .25s .15s, left .25s .1s, right .15s .175s;
-o-transition: border .25s .15s, left .25s .1s, right .15s .175s;
-ms-transition: border .25s .15s, left .25s .1s, right .15s .175s;
transition: border .25s .15s, left .25s .1s, right .15s .175s;
}
#milestone-table input[type="checkbox"]:checked {
border-color: #53d76a;
-webkit-box-shadow: inset 0 0 0 13px #53d76a;
box-shadow: inset 0 0 0 13px #53d76a;
padding-left: 18px;
-webkit-transition: border .25s, box-shadow .25s, padding .25s .15s;
-moz-transition: border .25s, box-shadow .25s, padding .25s .15s;
-o-transition: border .25s, box-shadow .25s, padding .25s .15s;
-ms-transition: border .25s, box-shadow .25s, padding .25s .15s;
transition: border .25s, box-shadow .25s, padding .25s .15s;
}
#milestone-table input[type="checkbox"]:checked:after {
border-color: #53d76a;
left: 26px;
right: 0;
-webkit-transition: border .25s, left .15s .25s, right .25s .175s;
-moz-transition: border .25s, left .15s .25s, right .25s .175s;
-o-transition: border .25s, left .15s .25s, right .25s .175s;
-ms-transition: border .25s, left .15s .25s, right .25s .175s;
transition: border .25s, left .15s .25s, right .25s .175s;
}
答案 0 :(得分:1)
可悲的是,这是Firefox中的一个老错误,据我所知还没有解决。如果它们最近没有改变(从你的问题来看,它们没有改变),无论你做什么,样式复选框和单选按钮在Firefox中都无法正常工作。
通常,解决此问题的常用方法是简单地使用常规div并让它们通过javascript或类似方法切换隐藏字段。绝对不是一个漂亮的解决方案,但在他们修复这个错误之前,你无能为力。
我使a quick example使用隐藏的复选框和标签实现了至少有效的功能。当然,它不仅仅是使用常规输入标签,但它应该在Firefox中工作(我猜IE,但我没有测试)。
<div id="milestone-table">
<p>Checkbox</p>
<label>
<input type="checkbox"/>
<label class="checkbox"/>
</label>
</div>