小提琴: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;
}
不幸的是,据我所知,这是Firefox中的一个旧错误,尚未修复。如果他们最近没有更改(从您的问题来看,他们没有更改),则无论您做什么,样式复选框和单选按钮都无法在Firefox中正常工作。
通常,解决此问题的常用方法是简单地使用常规div,然后让它们通过javascript或类似方法切换隐藏字段。绝对不是一个很好的解决方案,但是在他们解决此错误之前,您将无能为力。
我举了一个简短的示例,该示例使用隐藏的复选框和标签实现了至少有效的功能。当然,它不仅仅只是使用常规的输入标签,还可以在Firefox中运行(我猜是IE,但我尚未测试)。
<div id="milestone-table">
<p>Checkbox</p>
<label>
<input type="checkbox"/>
<label class="checkbox"/>
</label>
</div>
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句