jquery attr()方法獲取標籤的 checked 會有問題,因此用了 prop() 方法。jquery
Hml的checkbox沒有加name,只用了 div 嵌套。this
若有更好的方法,望指點!!spa
//全選 $('#allChecked').change(function(){ $('#box').children(':checkbox').prop('checked',$(this).is(':checked')?true:false); });
//反選 $('#invertChecked').change(function(){ if($(this).is(':checked')){ $('#box').children(':checkbox').each(function(){ $(this).prop('checked',$(this).is(':checked')?false:true); }); } });
1 //一鍵控制全選、反選、全不選 2 $('#orChecked').change(function(){ 3 if($(this).is(':checked')){ 4 var box = $('#box').children(':checkbox'); 5 if(box.length==box.filter(':not(:checked)').length){ // 複選框長度和沒選中的個數同樣 -> 全選 , .not(':checked').length 也能夠。 6 $('#box').children(':checkbox').prop('checked',true); 7 }else{ // 若是有選中個數,-> 反選 8 $('#box').children(':checkbox').each(function(){ 9 $(this).prop('checked',$(this).is(':checked')?false:true); 10 }); 11 }else{ 12 $('#box').children(':checkbox').prop('checked',false); // 如控制鍵取消選中,剩餘的checkbox也取消選中 13 } 14 15 });
1 <div align="center"> 2 3 <div id="box"> 4 <input type="checkbox" value="1">西瓜 5 <input type="checkbox" value="2">芒果 6 <input type="checkbox" value="3">橙 7 <input type="checkbox" value="4">山竹 8 <input type="checkbox" value="5">草莓 9 <input type="checkbox" value="6">火龍果 10 </div> 11 12 <br> 13 14 <input type="checkbox" id="allChecked">全選 15 <input type="checkbox" id="invertChecked">反選 16 <input type="checkbox" id="orChecked">全選/反選/全不選 17 18 </div>
若有更好的方法,望指點!!code