今天小編就爲大家分享一篇基於layui的table插件進行復選框聯動功能的實現方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
實際項目功能:
給員工賬號進行分配權限(增加權限,修改權限)
實現思路:
用表格展示權限列表–>勾選分配該賬號的權限–>調用接口
出現的問題:
因爲某些權限之間是有關聯的,比如: “ 查看材料 ” 和 “ 修改材料 ” ,這兩個權限是有聯繫的,當你勾選 “ 修改材料 ” 權限的時候,那麼, “ 查看材料 ” 權限也要勾選上,當你取消勾選 “ 查看材料 ”權限的時候,“ 修改材料 ” 權限也要取消。
所以當用戶勾選某個權限的時候,我們要通過js代碼去判斷是否有和這個權限相關的權限,如果有,就需要通過js代碼自動勾選或取消勾選。
而layui的table插件沒有提供通過js代碼自動勾選或取消勾選複選框的方法;
解決方案:
通過table的reload方法和form的render方法實現
思路:
//以查看材料和修改材料權限爲例:查看材料的id爲2,修改材料的id爲3 //用戶點擊複選框時,觸發的回調函數 table.on('checkbox(quanXianAll)', function(obj) { //判斷是否是全選 if (obj.type === "one") { //判斷判斷選中的權限是否爲“修改材料” if (obj.data.id === 3) { //判斷是否選中狀態 if (obj.checked) { tableIns.reload({ data:data, done: function (res) { //根據“查看材料”權限的id獲取的索引 var n = res.data.findIndex(function (item, i) { if (item.id === 2) { return true } }) //判斷查看材料”權限是否已被勾選 if(!res.data[n].LAY_CHECKED){ res.data[n].LAY_CHECKED = true; $(".layui-table-body").find("tr[data-index=" + n + "]").find('input[name="layTableCheckbox"]').prop("checked", true); form.render('checkbox'); } } }) } } } })
這種關聯肯定不止一個,所以我們要把代碼進行封裝。(思路應該說明白了,代碼就不再進行這裏封裝了)
在table的源文件中添加一個這樣的方法
在table源碼中的a.elem.on("click", 'input[name="layTableCheckbox"]+', function () {}方法內,添加以下方法
var mylaysetCheck= function (index,checked,callbacks) { var e=t("table[lay-filter="+f+"]").next().find(".layui-table-box").find(".layui-table-main").find("tr[data-index="+index+"]"), l = e.parents("tr").eq(0).data("index"), n = e[0].checked, o = "layTableAllChoose" === e.attr("lay-filter"); e.find('input[name="layTableCheckbox"]').prop("checked",checked); if(callbacks){ this.setCheckData(index, checked), this.syncCheckAll();a.renderForm("checkbox"); layui.event.call(this, s, "checkbox(" + f + ")", { checked: n, data: d.cache[a.key] ? d.cache[a.key][l] || {} : {}, type: o ? "all" : "one", mysetCheck:mylaysetCheck.bind(a) }) }else { this.setCheckData(index, checked), this.syncCheckAll();a.renderForm("checkbox"); } };
在table源碼中
a.elem.on("click", 'input[name="layTableCheckbox"]+', function () {}方法內有一個layui.event.call()函數===> 源碼爲: layui.event.call(this, s, "checkbox(" + f + ")", { checked: n, data: d.cache[a.key] ? d.cache[a.key][l] || {} : {}, type: o ? "all" : "one" })
改爲:
layui.event.call(this, s, "checkbox(" + f + ")", { checked: n, data: d.cache[a.key] ? d.cache[a.key][l] || {} : {}, type: o ? "all" : "one", mysetCheck:mylaysetCheck.bind(a) })
通過以下代碼調用
//用戶點擊複選框時,觸發的回調函數 table.on('checkbox(test)', function(obj){ //兩個參數,第一個是數組的索引,第二個是是否勾選,第三個是否使用回調函數 obj.mysetCheck(index,checked,callbacks); }); //案例:查看材料的id爲2,索引爲2;修改材料的id爲3,索引爲3 table.on('checkbox(quanXianAll)', function(obj){ if(obj.data.id===3&&obj.checked){ obj.mysetCheck(2,true,true); } if(obj.data.id===2&&!obj.checked){ obj.mysetCheck(3,false,true); } }); //這樣就可以實現:勾選“修改材料”時也會把“查看材料”勾選上,取消勾選“查看材料”時也會取消“修改材料”的勾選
對比:
第一種方法不用修改源碼,但代碼量多,且不是局部刷新;
第二種方法是局部刷新,代碼不多,但是修改源碼,設計到版本遷移的問題,且業務邏輯錯誤,容易發生無限循環;
以上這篇基於layui的table插件進行復選框聯動功能的實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持神馬文庫。