复选框,单选框都不好直接用css样式美化,总得用点奇思妙想才行。
如果只考虑谷歌内核的浏览器的话,那么用appearance属性可以搞定大部分表单控件的样式。关键是这个appearance属性IE不支持,这就逼得大家另想办法了。
利用label挂钩checkbox的特点来实现。
当html代码中,label的for属性值和checkbox的id值一样的时候,label就可以控制checkbox的选择了。
html代码如下:
<div id="check"> <input type="checkbox" id="btn-check"> <label for="btn-check"><span>全天</span></label> </div>
为label的伪元素添加背景图片,覆盖真正的checkbox对象,这样,既有图片的美观效果,又有checkbox一切的交互行为。
设计一个图片如下,默认状态,点击状态,不可用状态。
这里使用了定位,不然不能覆盖原始的复选框。而且文字和图片之间要间隔,文字也需要设置为定位对象。总之,这里都是定位关系。
这个效果只兼容IE9以上。
#check{
position:relative;}
input[type=checkbox]+label{
position:absolute;
width:60px;
height:20px;}
input[type=checkbox]+label:before{
content:"";
position:absolute;
width:20px;
height:20px;
background:url(images/btn1.png) no-repeat;
}
input[type=checkbox]+label span{
font-size:14px;
position:absolute;
left:30px;}
input[type=checkbox]:checked+label:before{
background-position:-28px 0;}
input[type=checkbox]{
position:absolute;
left:0;
top:0;}具体效果如下:

发表评论:
◎请发表你卖萌撒娇或一针见血的评论,严禁小广告。