溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

多個(gè)jquery.datatable共存,checkbox全選異常的快速解決方法

發(fā)布時(shí)間:2020-05-30 05:49:43 來源:網(wǎng)絡(luò) 閱讀:348 作者:xiaoxuanyunmeng 欄目:web開發(fā)

【問題原因】

這個(gè)應(yīng)該是 jquery.datatable 控件本身的一個(gè)缺陷。該控件中的checkbox小插件的 id是寫死的,所以當(dāng) 有多個(gè)datatable 引用到一個(gè)頁面中的時(shí)候,全選事件會匹配全部的datatable ,所以造成全部多個(gè)表格的 checkbox被都被選中。

【解決方法】

所以最好是修改jquery.datatable控件,給生成的每個(gè)datatable下的checkbox賦 予不同的id,因?yàn)閐atatable的id是不一樣的,所以可以把 datatable的id作為 checkbox的前綴組成一個(gè)唯一的id 。  具體這個(gè)checkbox的調(diào)用事件也需要同步 替換成這個(gè)新id,進(jìn)行事件的調(diào)用。

[修改文件]

jqurey.datatable.ext.js (v0.0.1)
unity3d下載 http://www.unitymanual.com/

1. init方法修改:
代碼如下:

$("#"+options.select_table).find('thead tr th:first-child')
        .prepend('<input type="checkbox" value="CHK_ALL" id=“chk_all" />');

==>

$("#"+options.select_table).find('thead tr th:first-child')
        .prepend('<input type="checkbox" value="CHK_ALL" id="'+options.select_table+'_chk_all" />');

2.subscribeAllChk方法修改:
代碼如下:

$("#chk_all").click(function(){

==>

$("#"+$.fn.datatable_ext.defaults.select_table+"_chk_all").click(function(){

3.subscribeChk方法修改:
代碼如下:

if(checked_chk_num == curr_page_chk_num){
     $("#chk_all").attr('checked', 'checked');
    }else{
     $("#chk_all").removeAttr('checked');
    }



==>

if(checked_chk_num == curr_page_chk_num){
     $("#"+$.fn.datatable_ext.defaults.select_table+"_chk_all").attr('checked', 'checked');
    }else{
     $("#"+$.fn.datatable_ext.defaults.select_table+"_chk_all").removeAttr('checked');
    }

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI