得益于 layui 良好的設(shè)計,可以順利擴(kuò)展 treeGrid 插件。支持樹狀表格、支持折疊記憶功能、支持動態(tài)新增行、支持動態(tài)刪除行、支持行內(nèi)過濾,支持方法式打開或折疊任意節(jié)點等等。內(nèi)部對原來table的渲染方法進(jìn)行了拆分,以便更精準(zhǔn)控制table的行為。
20180904
1、json數(shù)據(jù)源順序不再需要根節(jié)點在第一位,可以是無序(從數(shù)據(jù)庫中只需要查詢,不需要排序)
2、增加icon控制,默認(rèn)開啟圖標(biāo),提供默認(rèn)圖標(biāo),可自定義圖標(biāo)
3、多選:默認(rèn)選中,禁止選中等功能。
4、提供展開折疊全部節(jié)點功能,提供默認(rèn)值控制展開或折疊節(jié)點
在layui2.3的table組件基礎(chǔ)上獨立擴(kuò)展出來針對普通表格和樹狀表格的插件,主要增加如下功能。效果圖:
1、【增加】支持樹狀表格
2、【增加】支持折疊記憶功能(折疊的節(jié)點不受父節(jié)點折疊狀態(tài)影響)
3、【增加】動態(tài)新增行(一行或多行)
4、【優(yōu)化】動態(tài)刪除行(一行或多行)
5、【增加】行內(nèi)過濾(每次提交會自動提交此區(qū)域的參數(shù),需要結(jié)合后臺使用)
6、【增加】方法式打開或折疊任意節(jié)點(table.treeNodeOpen(o,isOpen))
7、【增加】數(shù)據(jù)刷新query方法(與reload方法區(qū)別在于,只刷新數(shù)據(jù)區(qū)域,而不是重新渲染整個table)
8、內(nèi)部對原來table的渲染方法進(jìn)行了拆分,以便更精準(zhǔn)控制table的行為(分別是生成單元格、生成tr、渲染分頁、渲染行內(nèi)過濾區(qū)域、渲染全部、渲染節(jié)點內(nèi)容等等)
<script>
var editObj=null,ptable=null,treeGrid=null,tableId='treeTable',layer=null;
layui.config({
base: 'design/extend/'
}).extend({
treeGrid:'treeGrid'
}).use(['jquery','treeGrid','layer'], function(){
var $=layui.jquery;
treeGrid = layui.treeGrid;//很重要
layer=layui.layer;
ptable=treeGrid.render({
id:tableId
,elem: '#'+tableId
,idField:'id'
,url:'/data2.json'
,cellMinWidth: 100
,treeId:'id'//樹形id字段名稱
,treeUpId:'pId'//樹形父id字段名稱
,treeShowName:'name'//以樹形式顯示的字段
,cols: [[
{width:100,title: '操作', align:'center'/*toolbar: '#barDemo'*/
,templet: function(d){
var html='';
var addBtn='<a class="layui-btn layui-btn-primary layui-btn-xs" lay-event="add">添加</a>';
var delBtn='<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">刪除</a>';
return addBtn+delBtn;
}
}
,{field:'name', edit:'text',width:300, title: '水果名稱'}
,{field:'id',width:100, title: 'id'}
,{field:'pId', title: 'pid'}
]]
,page:false
});
treeGrid.on('tool('+tableId+')',function (obj) {
if(obj.event === 'del'){//刪除行
del(obj);
}else if(obj.event==="add"){//添加行
add(obj.data);
}
});
});
function del(obj) {
layer.confirm("你確定刪除數(shù)據(jù)嗎?如果存在下級節(jié)點則一并刪除,此操作不能撤銷!", {icon: 3, title:'提示'},
function(index){//確定回調(diào)
obj.del();
layer.close(index);
},function (index) {//取消回調(diào)
layer.close(index);
}
);
}
var i=1000;
//添加
function add(pObj) {
var param={};
param.name='水果'+Math.random();
param.id=++i;
param.pId=pObj?pObj.id:0;
treeGrid.addRow(tableId,pObj?pObj.LAY_TABLE_INDEX+1:0,param);
}
function print() {
console.log(treeGrid.cache[tableId]);
var loadIndex=layer.msg("對象已打印,按F12,在控制臺查看!", {
time:3000
,offset: 'auto'//頂部
,shade: 0
});
}
</script>