如果你下定决心要改变现有的默认的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如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title></title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link rel="stylesheet" type="text/css" media="screen" href="grey.css" />
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="icheck.js"></script>
<style>
.checkbox-label {
position:relative;
display:block;
}
.hidebox {
opacity:0;
filter:alpha(opacity:0);
z-index:2;
position:relative;
}
.checkbox-label .checkbtn {
display:block;
width:12px;
height:12px;
left:5px;
top:-15px;
position:absolute;
background: url(checked.png) no-repeat;
}
.checkbox-label .uncheckbtn {
background: url(unchecked.png) no-repeat;
}
</style>
</head>
<body >
<div class="container">
<div class="header">
<h1>CheckBox And Radio Demo</h1>
</div>
<div>
<label class="checkbox-label">
<input type="checkbox" class="hidebox" checked/>复选框1号
<p class="checkbtn"></p>
</label>

<label class="checkbox-label">
<input type="checkbox" class="hidebox"/>复选框2号
<p class="checkbtn"></p>
</label>

<label class="checkbox-label">
<input type="checkbox" class="hidebox"/>复选框3号
<p class="checkbtn"></p>
</label>
</div>
</div>
<!-- /container -->
<script>
(function($){
$('input[type=checkbox]').on('click',function(){
var box = $(this),
mark = box.parent().find('.checkbtn');
$(this).prop('checked') ? mark.addClass('uncheckbtn') : mark.removeClass('uncheckbtn');
});
})(jQuery);
</script>

</body>
</html>

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

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

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

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<title></title>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<link rel="stylesheet" type="text/css" media="screen" href="grey.css" />
<script type="text/javascript" src="jquery.min.js"></script>
<script type="text/javascript" src="icheck.js"></script>
</head>
<body >
<div class="container">
<div class="header">
<h1>CheckBox And Radio Demo</h1>
</div>
<div>

<label class="checkbox-label">
<input type="checkbox" class="hidebox" id="box1" checked/>复选框1号
<p class="checkbtn"></p>
</label>

<label class="checkbox-label">
<input type="checkbox" class="hidebox" id="box2"/>复选框2号
<p class="checkbtn"></p>
</label>

<label class="checkbox-label">
<input type="checkbox" class="hidebox" id="box3"/>复选框3号
<p class="checkbtn"></p>
</label>

</div>
<div class="change">
<span class="toChecked">选中复选框1号和3号</span>
<span class="unChecked">取消选中复选框1号和3号</span>
<span class="toDisabled">disable复选框1号和3号单选框2号</span>
<span class="undisabled">取消disable复选框1号和3号单选框2号</span>
</div>
</div>
<!-- /container -->
<script>
$(document).ready(function(){
$('input').iCheck({
checkboxClass:'icheckbox_flat-grey',
radioClass:'iradio_flat-grey',
increaseArea:'20%'
});
});

$('.toChecked').click(function(){
$('#box1,#box3').iCheck('check');
});
$('.unChecked').click(function(){
$('#box1,#box3').iCheck('uncheck');
});
$('.toDisabled').click(function(){
$('#box1,#box3,#rad2').iCheck('disable');
});
$('.undisabled').click(function(){
$('#box1,#box3,#rad2').iCheck('enable');
});

</script>

</body>
</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');         });

转载于:https://www.cnblogs.com/axl234/p/3966723.html

checkbox和radio的样式美化问题相关推荐

  1. html表单复选框样式,美化表单——自定义checkbox和radio样式

    如果你对本站比较观注的话,应该很清楚,前面就有这方面的介绍.因为大家都知道表单中的部分元素如果单单使用CSS是没办法完成的,所以最近花全力在学习这方面的制作.在本站有关于这样制作有好几个教程了,比如说 ...

  2. Css实现checkbox及radio样式自定义

    前言 checkbox和radio样式自定义在网页中是很常见的, 比如在进行表单输入时性别的选择,用户注册时选择已阅读用户协议.随着用户对产品体验要求越来越高,我们都会对checkbox和radio重 ...

  3. IE下checkbox或radio隐藏bug

    由于各浏览器对checkbox或radio的渲染效果各不相同,为了美化和统一界面样式,一般会选择用js和css来自定义checkbox或radio的样式,此时一般会隐藏原始的checkbox或radi ...

  4. 微信小程序:修改单选radio大小样式

    通过scale将其缩小 <radio style="transform:scale(0.8)" checked="true" value="tr ...

  5. html5复选框样式,11种炫酷CSS3复选框checkbox样式美化效果

    这是一款效果非常酷的CSS3复选框checkbox样式美化效果.该复选框美化效果共有11种.默认的复选框的样式十分不好看,该效果将复选框加一美化,带上了一些动画效果,其中一些制作为滑动按钮的样式. 使 ...

  6. HTML的checkbox和radio的美化

    HTML的checkbox和radio的美化 原文:HTML的checkbox和radio的美化 checkbox和radio的美化 checkbox: <style type="te ...

  7. 微信小程序checkbox样式美化

    微信小程序checkbox默认默认样式显得非常不美观,需对其进行样式美化, 样式美化后的结果: 代码如下: html: <checkbox-group data-id="{{item. ...

  8. html改变复选框颜色,如何利用纯CSS改变html?radio/checkbox默认背景颜色样式

    本篇文章给大家带来的内容是关于如何利用纯CSS改变html?radio/checkbox默认背景颜色样式,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. CSS代码:input[typ ...

  9. input checkbox样式美化

    input checkbox样式美化 最近在学校做自己的学习实践项目中,用到了checkbox,想实现的是,在登陆界面的中的那个记住我的选框.我们都知道,原生的checkbox样式不能满足咱们的需求. ...

最新文章

  1. 我是如何用机器学习技术帮助 HR 省时间的
  2. Winform中怎样获取项目图片资源并转换为Image对象
  3. 【译】Build Knowledge Graph from unstructured corpus using Machine Learning
  4. 算法组合 优化算法_算法交易简化了风险价值和投资组合优化
  5. 2020-2021年中国购物中心消费者洞察报告
  6. 随机密码生成python_让“全家福”更加随机 —— 自动生成照片布局之Python实现...
  7. 3D人脸重建算法汇总
  8. 多媒体计算机技术未来的发展方向,多媒体技术的发展现状及未来
  9. [图形学]拉普拉斯网格变形(Laplace Deformation)原理及复现
  10. win10 移动硬盘“拒绝访问”解决方案
  11. RationalDMIS 2020 编程技巧
  12. 针孔相机模型,鱼眼相机模型,单目标定
  13. php流程管理软件,MYSQL数据库管理软件PHPAdmin操作流程
  14. linux gcc error cc1,gcc找不到cc1plus
  15. html中表格行删除的方法,HTML删除表格行中的空格
  16. OpenGL: gluLookAt函数的含义
  17. Linux常用命令(适合初学者)
  18. SOA,SOAP,RPC,以及 RPC协议与 REST 协议之间的关系(搜狗)
  19. 中科大计算机科学夏令营,中科大计算机保研夏令营
  20. flex布局属性的伸展、收缩、基准属性

热门文章

  1. 一个专业搜索公司关于lucene+solar资料
  2. 使用 Jersey 和 Apache Tomcat 构建 RESTful Web 服务
  3. Loadrunner 入门连载教程
  4. 201771010125王瑜《面向对象程序设计(Java)》第六周学习总结
  5. java设计模式演示样例
  6. SQL Server数据文件迁移
  7. android引用另一个项目作为library错误
  8. xml.modify() 实例演示(二)
  9. about EnableEventValidation 这是什么意思,欢迎指点一下,谢谢
  10. 2019百度之星初赛1