原生JS版和jquery版實(shí)現(xiàn)checkbox的全選/全不選/點(diǎn)選/行內(nèi)點(diǎn)選(Mr.Think)
日常項(xiàng)目中, 對于列表類文章或數(shù)據(jù), 大概都會用到checkbox的全選或全不選的功能, 以前的項(xiàng)目中也寫過checkbox的選擇js, 但都沒有整理過. 正好前幾天一個兄弟遇到了這個問題, 索性, 我花了點(diǎn)時間, 用原生JS與jQuery分別寫了一個版本, 考慮到使用時靈活性問題, 未封裝, 需要的童鞋使用時自行改下相關(guān)參數(shù).

功能介紹點(diǎn)此查看DEMO演示
1. 全選/全不選 選框一體實(shí)現(xiàn), 即列表中選框的狀態(tài)與全選/全不選框前的選框狀態(tài)一致;
2. 自動更改 全選/全不選 選框的狀態(tài), 即列表中選框都選中時, 全選/全不選 選框也選中, 反之亦然;
3. 列表行內(nèi)點(diǎn)擊也可選中行內(nèi)的checkbox, 并與1,2中的功能聯(lián)動.
另,本文重在寫全選, 鼠標(biāo)劃入劃出背景變色為簡易實(shí)現(xiàn), 更加完善的請參考:
http://www.dhdzp.com/article/24125.htm
原生JS版本核心代碼
html代碼
<form id="js" name="js" action="#"> <h5>原生JS樣例</h5> <dl> <dt><label for="js_chk_0"><input type="checkbox" id="js_chk_0" name="chk_can" value="" />全選/全不選</label></dt> <dd><span>2010-12-12</span><input type="checkbox" name="jsitems" value="" />原生JS實(shí)現(xiàn)的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jsitems" value="" />原生JS實(shí)現(xiàn)的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jsitems" value="" />原生JS實(shí)現(xiàn)的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jsitems" value="" />原生JS實(shí)現(xiàn)的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jsitems" value="" />原生JS實(shí)現(xiàn)的全選/全不選,點(diǎn)行也可選中或取消</dd> <dt><label for="js_chk_1"><input type="checkbox" id="js_chk_1" name="chk_can" value="" />全選/全不選</label></dt> </dl> </form>
原生js代碼
//原生JS實(shí)現(xiàn)全選全不選類
window.onload = function iCheckAll(){
var js_chk = document.forms['js'].chk_can;
var jsitems = document.forms['js'].jsitems;
var jsrows = document.getElementById('js').getElementsByTagName('dd');
//判斷選中個數(shù)與實(shí)際選框個數(shù)實(shí)現(xiàn)全選/全不選框的狀態(tài)
var chk_canle = function(){
var checkedLen = 0;
//計(jì)算列表中選中狀態(tài)的選框個數(shù)
for (var m = 0; m < jsitems.length; m++) {
if (jsitems[m].checked) {
checkedLen += 1;
}
}
//判斷選中個數(shù)與實(shí)際個數(shù)是否相同,以確定全選/全不選狀態(tài)
for (var m = 0; m < js_chk.length; m++) {
js_chk[m].checked = (jsitems.length == checkedLen);
}
}
//全選與全不選一體實(shí)現(xiàn)
for (var i = 0; i < js_chk.length; i++) {
js_chk[i].onclick = function(){
//列表中選框與全選選框統(tǒng)一狀態(tài)
for (var m = 0; m < jsitems.length; m++) {
jsitems[m].checked = this.checked;
}
//全選選框統(tǒng)一狀態(tài)
for (var m = 0; m < js_chk.length; m++) {
js_chk[m].checked = this.checked;
}
}
}
//列表中選框點(diǎn)擊
for (var i = 0; i < jsitems.length; i++) {
jsitems[i].onclick = function(e){
//阻止冒泡,避免行點(diǎn)擊事件中,直接選擇選框無效
e && e.stopPropagation ? e.stopPropagation() : window.event.cancelBubble=true;
chk_canle();
}
}
//行內(nèi)點(diǎn)擊
for (var i = 0; i < jsrows.length; i++) {
jsrows[i].onclick = function(){
//行內(nèi)點(diǎn)擊時,行內(nèi)的選框狀態(tài)為原狀態(tài)取反
this.getElementsByTagName('input')[0].checked = !this.getElementsByTagName('input')[0].checked;
chk_canle();
}
//劃入劃出請參考http://mrthink.net/javascript-tagnames-highlight/
jsrows[i].onmouseover = function(){
this.className = 'hover';
}
jsrows[i].onmouseout = function(){
this.className = '';
}
}
}
jquery版本核心代碼
html代碼
<form id="jq" name="jq" action="#"> <h5>jQuery樣例</h5> <dl> <dt><label for="jq_chk_0"><input type="checkbox" id="jq_chk_0" name="chk_can" value="" />全選/全不選</label></dt> <dd><span>2010-12-12</span><input type="checkbox" name="jqitems" value="" />基于jQuery的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jqitems" value="" />基于jQuery的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jqitems" value="" />基于jQuery的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jqitems" value="" />基于jQuery的全選/全不選,點(diǎn)行也可選中或取消</dd> <dd><span>2010-12-12</span><input type="checkbox" name="jqitems" value="" />基于jQuery的全選/全不選,點(diǎn)行也可選中或取消</dd> <dt><label for="jq_chk_1"><input type="checkbox" id="jq_chk_1" name="chk_can" value="" />全選/全不選</label></dt> </dl> </form>
jquery核心實(shí)現(xiàn)代碼
//jQ實(shí)現(xiàn)全選全不選
$(function(){
var _jq_chk = $('#jq>dl>dt>label>:checkbox');
var _jqitems = $(':checkbox[name=jqitems]');
var _rows = $('#jq>dl>dd');
//全選與全不選一體實(shí)現(xiàn)
_jq_chk.click(function(){
//列表中選框和全選選框統(tǒng)一狀態(tài)
_jqitems.add(_jq_chk).attr('checked', this.checked);
});
//選框的點(diǎn)擊事件
_jqitems.click(function(e){
//阻止冒泡,避免行點(diǎn)擊事件中,直接選擇選框無效
e.stopPropagation();
//判斷選中個數(shù)與實(shí)際個數(shù)是否相同,以確定全選/全不選狀態(tài)
_jq_chk.attr('checked', _jqitems.size() == _jqitems.filter(':checked').size());
});
//點(diǎn)選行時選中行內(nèi)的checkbox
_rows.bind({
mouseenter: function(){
$(this).addClass('hover');
},
mouseleave: function(){
$(this).removeClass('hover');
},
//點(diǎn)選
click: function(){
//行內(nèi)點(diǎn)擊時,行內(nèi)的選框狀態(tài)為原狀態(tài)取反
$(this).find(':checkbox').attr('checked', !$(this).find(':checkbox').get(0).checked)
//判斷選中個數(shù)與實(shí)際個數(shù)是否相同,以確定全選/全不選狀態(tài)
_jq_chk.attr('checked', _jqitems.size() == _jqitems.filter(':checked').size());
}
});
});
這個代碼比普通的實(shí)現(xiàn)代碼要多不少,主要表現(xiàn)為點(diǎn)擊行就可以實(shí)現(xiàn)選擇功能。更多的功能更多的代碼。大家可以根據(jù)需要自行刪減。
相信很多做web的人都會遇到一些JS問題,那到底是用JQ來實(shí)現(xiàn)還是用JS來實(shí)現(xiàn),常常困擾著我們,但其實(shí)JS是通用的,而JQ是建在自己加載的JQ庫的,所在真正實(shí)現(xiàn)是沒有任何區(qū)別的。
- js實(shí)現(xiàn)全選和全不選
- js實(shí)現(xiàn)全選和全不選功能
- Js實(shí)現(xiàn)復(fù)選框的全選、全不選反選功能代碼實(shí)例
- JS實(shí)現(xiàn)“全選”和"全不選"功能代碼實(shí)例
- JS實(shí)現(xiàn)CheckBox復(fù)選框全選、不選或全不選功能
- js與jQuery實(shí)現(xiàn)checkbox復(fù)選框全選/全不選的方法
- JS實(shí)現(xiàn)CheckBox復(fù)選框全選全不選功能
- 使用js如何實(shí)現(xiàn)全選與全不選
- jquery全選/全不選/反選另一種實(shí)現(xiàn)方法(配合原生js)
- JavaScript實(shí)現(xiàn)全選和全不選操作
相關(guān)文章
Echarts.js實(shí)現(xiàn)水滴球和海洋效果
這篇文章介紹了Echarts.js實(shí)現(xiàn)水滴球和海洋效果的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-04-04
一文詳解JSON.parse和JSON.stringify的用法
Json.stringify()和toString()兩者雖然都可以講目標(biāo)值轉(zhuǎn)為字符串,但是還是有本質(zhì)區(qū)別的,下面這篇文章主要給大家介紹了關(guān)于JSON.parse和JSON.stringify用法的相關(guān)資料,需要的朋友可以參考下2023-01-01
javascript 框架小結(jié) 個人工作經(jīng)驗(yàn)
javascript 框架小結(jié) 個人工作經(jīng)驗(yàn),對于新手來說還是值得學(xué)習(xí)的。2009-06-06
JavaScript對象與數(shù)組的幾種常見復(fù)制方法
在 JavaScript 開發(fā)中,對象和數(shù)組的復(fù)制是一個非常常見的操作,無論是函數(shù)參數(shù)傳遞、狀態(tài)管理,還是避免不必要的副作用,了解和掌握各種復(fù)制方式至關(guān)重要,我們將系統(tǒng)梳理 JavaScript 中的幾種常見復(fù)制方法,并對其應(yīng)用場景進(jìn)行詳細(xì)說明,需要的朋友可以參考下2024-10-10
微信小程序?qū)崿F(xiàn)隨機(jī)驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)隨機(jī)驗(yàn)證碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
javascript 動態(tài)改變層的Z-INDEX的代碼style.zIndex
javascript 動態(tài)改變層的Z-INDEX的代碼style.zIndex...2007-08-08

