zoukankan      html  css  js  c++  java
  • 论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默认的丑样式,两种方法都可任你选择。

  • 相关阅读:
    Could not load file or assembly Microsoft.SqlServer.management.sdk.sfc version 11.0.0.0
    代码覆盖率 (Code Coverage)从简到繁 (一)
    vscode配置自动格式化eslint 配置模板
    无效的源发行版: 10
    java读取一个文件写入另外一个文件
    notepad++使用正则表达式匹配
    jsp页面返回字符串而非方法执行后取得的数据?
    maven的原始setting.xml文件,自带阿里云镜像,之前配的时候出错,保存一下,注意可以在localRepository处设置存储依赖的地址,大概在49到54行,我的是<localRepository>F:/MavenRepository</localRepository>,F盘要先有这个文件夹
    Java 8 lambda Stream list to Map key 重复 value合并到Collection
    BufferedReader.readLine()读取文件
  • 原文地址:https://www.cnblogs.com/skylar/p/3909634.html
Copyright © 2011-2022 走看看