
引入jquery库
<script src="ajax/libs/jquery/1.10.2/jquery.min.js"></script>
构建HTML
一般从数据库读出来的列表都需要批量选中以便删除与编辑等,下面我们就来模拟下,实现复选框checkbox的全选与不选,先建立html
<ul id="list"><li><label><input type="checkbox" value="1"> 1.我是记录来的呢</label></li><li><label><input type="checkbox" value="2"> 2.哈哈,真的太天真了</label></li><li><label><input type="checkbox" value="3"> 3.爱上你是我的错吗?</label></li><li><label><input type="checkbox" value="4"> 4.从开始你就不应用爱上我</label></li><li><label><input type="checkbox" value="5"> 5.喜欢一个人好难</label></li><li><label><input type="checkbox" value="6"> 6.你在那里呢</label></li> </ul> <input type="checkbox" id="all"> <input type="button" value="全选" class="btn" id="selectAll"> <input type="button" value="全不选" class="btn" id="unSelect"> <input type="button" value="反选" class="btn" id="reverse"> <input type="button" value="获得选中的所有值" class="btn" id="getValue">jQuery 代码
$("#all").click(function(){if(this.checked){ $("#list :checkbox").attr("checked", true);}else{ $("#list :checkbox").attr("checked", false);} });2、全选。当点击全选按钮#selectAll或者勾选全选按钮旁边的复选框#all时,列表中所有的选项都会被选中,包括全选旁边的复选框也是选中状态。$("#selectAll").click(function () {$("#list :checkbox,#all").attr("checked", true); });3、全不选。当点击全不选按钮#unSelect时,列表中所有的选项都是未选中状态,当然包括#all也是未选中状态。$("#unSelect").click(function () {$("#list :checkbox,#all").attr("checked", false); });4、反选。当点击反选按钮#reverse,列表中所有被选中的选项变为未选中状态,而所有未选中的选项变为已选中状态,当然也要注意#all的状态。$("#reverse").click(function () {$("#list :checkbox").each(function () { $(this).attr("checked", !$(this).attr("checked"));});allchk(); });代码中遍历了选项列表,然后改变checked属性,最后调用函数allchk(),后面将介绍该函数。$("#getValue").click(function(){var valArr = new Array;$("#list :checkbox[checked]").each(function(i){ valArr[i] = $(this).val();});var vals = valArr.join(",");//转换为逗号隔开的字符串alert(vals); });为了完善选中选项功能,我们在单击列表中某个选项时,如果勾选的项刚好满足全部选中的条件,则#all也要相应的变为选中状态,同样,如果事先所有的选项是选中状态时,当取消勾选某个选项时,那么#all也要相应的变为未选中状态。//设置全选复选框 $("#list :checkbox").click(function(){allchk(); });函数allchk()就是用来检测全选框#all应该是选中状态还是未选中状态的,请看代码。function allchk(){var chknum = $("#list :checkbox").size();//选项总个数var chk = 0;$("#list :checkbox").each(function () { if($(this).attr("checked")==true){chk++; }});if(chknum==chk){//全选 $("#all").attr("checked",true);}else{//不全选 $("#all").attr("checked",false);} }总结$(function () {//全选或全不选$("#all").click(function(){ if(this.checked){$("#list :checkbox").attr("checked", true); }else{$("#list :checkbox").attr("checked", false); } });//全选$("#selectAll").click(function () {$("#list :checkbox,#all").attr("checked", true);});//全不选$("#unSelect").click(function () {$("#list :checkbox,#all").attr("checked", false);});//反选$("#reverse").click(function () {$("#list :checkbox").each(function () { $(this).attr("checked", !$(this).attr("checked"));});allchk();});//设置全选复选框$("#list :checkbox").click(function(){ allchk();}); //获取选中选项的值$("#getValue").click(function(){ var valArr = new Array; $("#list :checkbox[checked]").each(function(i){valArr[i] = $(this).val(); }); var vals = valArr.join(",");alert(vals);}); }); function allchk(){var chknum = $("#list :checkbox").size();//选项总个数var chk = 0;$("#list :checkbox").each(function () { if($(this).attr("checked")==true){chk++; }});if(chknum==chk){//全选 $("#all").attr("checked",true);}else{//不全选 $("#all").attr("checked",false);} }通过本文希望大家对jquery中checkbox的使用方法有个大概的认识,再通过大量实例熟练掌握checkbox使用方法。