论checkbox和radio的样式美化问题

如果你下定决心要改变现有的默认的checkbox和radio的样式,那么我目前有两种办法:

1、自己动手写一个,也就是自己写代码实现将input的checkbox和radio默认的样式隐藏掉,使用绝对定位的方式,手动切换checked和unchecked的图片,定位到原来input显示的地方;

2、使用jQuery的iCheck插件 。

中文DOC地址:http://www.bootcss.com/p/icheck/

github地址:https://github.com/fronteed/iCheck

一、先来说说第一种办法吧,我觉得这个是最好的,又不用多添加js,自己写几行代码就行了。

demo如下:

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
 3 <head>
 4   <title></title>
 5   <meta http-equiv="content-type" content="text/html; charset=utf-8" />
 6   <link rel="stylesheet" type="text/css" media="screen" href="grey.css" />
 7   <script type="text/javascript" src="jquery.min.js"></script>
 8   <script type="text/javascript" src="icheck.js"></script>
 9    <style>
10       .checkbox-label {
11           position:relative;
12           display:block;
13        }
14        .hidebox {
15           opacity:0;
16           filter:alpha(opacity:0);
17           z-index:2;
18           position:relative;
19        }
20        .checkbox-label .checkbtn {
21           display:block;
22           width:12px;
23           height:12px;
24           left:5px;
25           top:-15px;
26           position:absolute;
27           background: url(checked.png) no-repeat;
28        }
29        .checkbox-label .uncheckbtn {
30           background: url(unchecked.png) no-repeat;
31        }
32    </style>
33 </head>
34 <body >
35   <div class="container">
36     <div class="header">
37       <h1>CheckBox And Radio Demo</h1>
38     </div>
39     <div>
40        <label class="checkbox-label">
41           <input type="checkbox" class="hidebox" checked/>复选框1号
42           <p class="checkbtn"></p>
43         </label>
44
45         <label class="checkbox-label">
46           <input type="checkbox" class="hidebox"/>复选框2号
47           <p class="checkbtn"></p>
48         </label>
49
50         <label class="checkbox-label">
51           <input type="checkbox" class="hidebox"/>复选框3号
52           <p class="checkbtn"></p>
53         </label>
54     </div>
55   </div>
56   <!-- /container -->
57   <script>
58         (function($){
59           $(‘input[type=checkbox]‘).on(‘click‘,function(){
60              var box = $(this),
61                  mark = box.parent().find(‘.checkbtn‘);
62              $(this).prop(‘checked‘) ? mark.addClass(‘uncheckbtn‘) : mark.removeClass(‘uncheckbtn‘);
63           });
64         })(jQuery);
65 </script>
66
67 </body>
68 </html>

这是一个朋友(大牛)教我的方法,代码又少,写得又好,我也很喜欢。

这里面有的说的我感觉就是attr()和prop()方法,以前我没觉得有什么不同。但实际上还是有区别,简单来说吧,如果你想得到字符串的属性值的话那么就要用attr(),但如果你的本意是获得bool值得话,那么就要用prop()了。

二、那么如果你的项目比较大,兼容性封装性等各个方面要求比较严格的话,那么你可以尝试一下iCheck插件,但我目前还存在问题,如果你的checkbox和radio的功能比较简单的话,那么没有任何问题,但是如果你有全选部分选择的功能的话,那么你可能要花点心思了,我现在列出我的使用方法和心得,如果你有更好的解决其中问题的方法的话,请教教我喔,感激不尽。

简单使用真的简单,demo如下:

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
 3 <head>
 4   <title></title>
 5   <meta http-equiv="content-type" content="text/html; charset=utf-8" />
 6   <link rel="stylesheet" type="text/css" media="screen" href="grey.css" />
 7   <script type="text/javascript" src="jquery.min.js"></script>
 8   <script type="text/javascript" src="icheck.js"></script>
33 </head>
34 <body >
35   <div class="container">
36     <div class="header">
37       <h1>CheckBox And Radio Demo</h1>
38     </div>
39     <div>
40
41
42         <label class="checkbox-label">
43           <input type="checkbox" class="hidebox" id="box1" checked/>复选框1号
44           <p class="checkbtn"></p>
45         </label>
46
47         <label class="checkbox-label">
48           <input type="checkbox" class="hidebox" id="box2"/>复选框2号
49           <p class="checkbtn"></p>
50         </label>
51
52         <label class="checkbox-label">
53           <input type="checkbox" class="hidebox" id="box3"/>复选框3号
54           <p class="checkbtn"></p>
55         </label>
56
57
58
59     </div>
60     <div class="change">
61       <span class="toChecked">选中复选框1号和3号</span>
62       <span class="unChecked">取消选中复选框1号和3号</span>
63       <span class="toDisabled">disable复选框1号和3号单选框2号</span>
64       <span class="undisabled">取消disable复选框1号和3号单选框2号</span>
65     </div>
66   </div>
67   <!-- /container -->
68   <script>
69     $(document).ready(function(){
70         $(‘input‘).iCheck({
71           checkboxClass:‘icheckbox_flat-grey‘,
72           radioClass:‘iradio_flat-grey‘,
73           increaseArea:‘20%‘
74         });
75        });
76
77        $(‘.toChecked‘).click(function(){
78              $(‘#box1,#box3‘).iCheck(‘check‘);
79        });
80        $(‘.unChecked‘).click(function(){
81              $(‘#box1,#box3‘).iCheck(‘uncheck‘);
82        });
83        $(‘.toDisabled‘).click(function(){
84              $(‘#box1,#box3,#rad2‘).iCheck(‘disable‘);
85        });
86        $(‘.undisabled‘).click(function(){
87              $(‘#box1,#box3,#rad2‘).iCheck(‘enable‘);
88        });
89
90
91   </script>
92
93 </body>
94 </html>

然后去下载iCheck.js和像grey.css(多种可选)这样的样式文件就可以了,简单的就可以换样式了喔。

但是如果你想用到项目里,可能就没这么简单了。我踩过的坑有:

1、虽然iCheck的实现原理是在input外包裹一层div用来实现样式图片的切换,跟我们手动实现的原理差不多,但是虽然我们可能在浏览器中不容易显示的看出来,实际上input的checked属性也已经切换了;

2、如果你的input部分是在js中动态写进去的话,那么就要注意你有关iCheck的代码的位置,一定要等到dom全部加载完成之后。iCheck才会起作用。

3、还有一个还没有迈出来的坑,如果你的项目这个相关的功能需要完成,那么你可能需要在回调函数中完成一些操作,我的问题就在于,里面的操作实际上已经完成了(控制台可查看),但是我在其中调用的iCheck()方法,却不起作用了,看了很多github上的issue,相同问题很多。

like this:

$("#_hs_select_all").on(‘ifChecked‘,function(){
            $("._hs_item_cb").prop(‘checked‘,true).iCheck(‘check‘);
            $("._hs_item_cld_cb").prop(‘checked‘,true).iCheck(‘check‘);
         }).on(‘ifUnchecked‘,function(){
             $("._hs_item_cb").prop(‘checked‘,false).iCheck(‘uncheck‘);
             $("._hs_item_cld_cb").prop(‘checked‘,false).iCheck(‘uncheck‘);         });

我也尝试过换2.x版本,但问题似乎更多,待解。

如果你也在换掉checkbox和radio默认的丑样式,两种方法都可任你选择。

论checkbox和radio的样式美化问题

时间: 2024-10-11 11:50:19

论checkbox和radio的样式美化问题的相关文章

checkbox和radio的样式美化问题

如果你下定决心要改变现有的默认的checkbox和radio的样式,那么我目前有两种办法: 1.自己动手写一个,也就是自己写代码实现将input的checkbox和radio默认的样式隐藏掉,使用绝对定位的方式,手动切换checked和unchecked的图片,定位到原来input显示的地方: 2.使用jQuery的iCheck插件 . 中文DOC地址:http://www.bootcss.com/p/icheck/ github地址:https://github.com/fronteed/iC

巧用CSS3伪类选择器自定义checkbox和radio的样式

由于原生的checkbox和radio的样式太简陋了,在设计页面的时候,设计师往往会设计自己的checkbox和radio样式.一半情况下,为了适应各个浏览器的兼容性,我们都会用其他的元素替代原生的checkbox和radio,然后用js实现选中和未选中时候的样式,用来模拟checkbox和radio. 例如这种: 用其他元素模拟(以checkbox为例): <div class='checkbox'></div> $('.checkbox').click(function(){

纯css自定义checkbox和radio的样式

以上是结构.说明一下,这样写是为了展示点击文字即可选中的两种方式,因为之前我一直忽略了第二种方法. css部分也是分开写的,其实基本一样,只是为了更直观看清楚: div{ width:200px; height:100px; background:#013879; padding:15px; color:#fff; font-size:14px;} 改变checkbox: .checkbox{ width:12px; height:13px; background:#fff; border:1p

[ HTML5 表单样式 checkbox | radio ] 自定义checkbox 与radio样式实现思路

自定义checkbox 与radio样式实现思路: 1.隐藏原生的input选框  2.自定义新的选框  3.并通过CSS或JS控制切换是否选中的状态 声明:转载自网络,本人只作为学习之用,如果原作者发现(觉着)有侵权意图敬请联系本人,删除或修改,本人尊重原文作者的劳动并对原文作者的分享表示感谢和敬意... 分析原理: 实现 1.结构:用label绑定input,推荐使用label包裹input,以减少不必要的id: 2.样式:隐藏input标签,为label添加背景或使用其他小标签(<i>&

支付宝小程序开发——修改小程序原生radio默认样式

如下,要做这样的单选按钮,小程序原生的单选按钮使用起来还算是比较方便的,所以选择直接进行样式改造了: 对于微信小程序来说,单选按钮实质上是一个有自己内部结构的组件,内部有自己的元素结构,所以在重定义样式的时候,需要用到组件你内部的元素类名来定义,详见:微信小程序开发——修改小程序原生checkbox.radio默认样式. 不同于微信小程序,支付宝小程序的大部分组件及样式跟Html都比较接近的.对于单选按钮,则与html标签类似,可以采用同样的方法进行样式修改.具体如下: /* 单选按钮样式*/

checkbox和radio样式美化

看惯了input[checkbox]和input[radio]默认样式,有没有想要改变一下呢?比如下面的样式: 比起html默认的样式,上图这些是不是美观多了呢?并且这样的input美化,无需jquery插件,只要几行css代码就可以. 思路 思路很简单:(1)将之前的按钮透明度opacity设置为0:(2)外层用div包裹 实现过程 图片下载:       [html代码] <div class="hdz_input_radio checked"><input ty

css input checkbox和radio样式美化

css input checkbox和radio样式美化 2014年9月1日 132495次浏览 在之前的一篇文章中,我已经介绍了input file上传按钮的美化,地址:http://www.haorooms.com/post/css_input_uploadmh ,今天,我们来讲一下checkbox美化和radio美化,关于select下拉框的美化的话,要用一个jquery插件了,这个插件后面我们再讲!急用的同学可以留言! 但是像checkbox美化和radio美化,input美化,根本就不

jQuery实现自定义checkbox和radio样式

jQuery实现自定义checkbox和radio样式 1,起因 最近在工作中要实现自定义式的radio样式,而我们通常使用的时默认的样式,因为自己实在想不到解决的方法,于是开始搜索,最终看到了不错的解决办法,可以完美解决我们遇到的问题. 2,原理 大家都知道在写结构的时候,radio或checkbox都会跟随label一起使用,label的for属性值和input的id值相同的情况下,点击label就可以选中input,这里正是利用label 来覆盖我们的input默认样式,通过给label添

自定义表单样式之checkbox和radio

1,起因 最近在工作中要实现自定义式的radio样式,而我们通常使用的时默认的样式,因为自己实在想不到解决的方法,于是开始搜索,最终看到了不错的解决办法,可以完美解决我们遇到的问题. 2,原理 大家都知道在写结构的时候,radio或checkbox都会跟随label一起使用,label的for属性值和input的id值相同的情况下,点击label就可以选中input,这里正是利用label 来覆盖我们的input默认样式,通过给label添加背景图片(美化的checkbox或radio),也就是