jQuery 全选、反选和全不选

HTML代码:

<div id="list">

   
	<input type="checkbox" value="1"> 1.时间都去哪儿了
	<input type="checkbox" value="2"> 2.海阔天空
    <input type="checkbox" value="3"> 3.真的爱你
    <input type="checkbox" value="4"> 4.不再犹豫
    <input type="checkbox" value="5"> 5.光辉岁月
    <input type="checkbox" value="6"> 6.喜欢妳
	
  	<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">  
</div>

jquery代码:

<script>  
$(function () {
	//全选或全不选
	$("#all").click(function(){   
    	if(this.checked){   
        	$("#list :checkbox").prop("checked", true);  
    	}else{   
		    $("#list :checkbox").prop("checked", false);
    	}   
 	}); 
	//全选  
    $("#selectAll").click(function () {
         $("#list :checkbox,#all").prop("checked", true);  
    });  
	//全不选
    $("#unSelect").click(function () {  
         $("#list :checkbox,#all").prop("checked", false);  
    });  
    //反选 
    $("#reverse").click(function () { 
         $("#list :checkbox").each(function () {  
              $(this).prop("checked", !$(this).prop("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").length;//选项总个数
	var chk = 0;
	$("#list :checkbox").each(function () {  
        if($(this).prop("checked")==true){
			chk++;
		}
    });
	if(chknum==chk){//全选
		$("#all").prop("checked",true);
	}else{//不全选
		$("#all").prop("checked",false);
	}
}
</script> 

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

微信扫一扫

微信扫一扫

微信扫一扫,分享到朋友圈

jQuery   全选、反选和全不选