layui/examples/treeTable.html
2023-09-11 11:14:51 +08:00

115 lines
2.9 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>树形表格 - layui</title>
<link rel="stylesheet" href="../src/css/layui.css">
<style>
body {padding: 32px;}
</style>
</head>
<body>
<table class="layui-hide" id="test"></table>
<script type="text/html" id="TPL-treeTable-demo">
<div class="layui-btn-container">
<button class="layui-btn layui-btn-sm" lay-event="getChecked">获取选中数据</button>
</div>
</script>
<script src="../src/layui.js"></script>
<script>
layui.use(['treeTable'], function(){
var treeTable = layui.treeTable;
// 渲染
treeTable.render({
elem: '#test',
url: './json/treeTable/demo-1.json',
maxHeight: 'full-32',
toolbar: '#TPL-treeTable-demo',
tree: {
customName: {
name: 'name'
},
view: {
iconLeaf: ''
}
},
cols: [[
{type: 'checkbox', fixed: 'left'},
{type: 'numbers', fixed: 'left'},
{field: 'id', title: 'ID', width: 145, sort: true, fixed: 'left', totalRow: '合计:'},
{field: 'name', title: '用户名', width: 180, fixed: 'left'},
{field: 'experience', title: '积分', width: 90, sort: true},
{field: 'sex', title: '性别', width: 80, sort: true},
{field: 'score', title: '评分', width: 80, sort: true},
{field: 'city', title: '城市', width: 150},
{field: 'description', title: '描述', minWidth: 200},
{field: 'createTime', title: '创建时间', width: 170, fixed: 'right'}
]],
page: true
});
// 单元格工具事件
treeTable.on('row(test)', function (obj) {
console.log(obj);
});
});
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/Mock.js/1.0.0/mock-min.js"></script>
<script>
// 生成模拟数据
const createData = () => {
// 生成随机 ID 函数
const createId = (() => {
let nextId = 1
return () => nextId++
})()
// 生成节点函数
const createNode = (parentId = null, level = 0) => {
const id = createId()
const children = level < 3 ? Mock.mock({
'array|0-5': [
createNode.bind(null, id, level + 1)
]
}).array : []
return {
id,
name: `User-${id}`,
type: Mock.mock('@d6'),
status: Mock.Random.d4(),
score: Mock.Random.d100(),
experience: Mock.Random.integer(1000, 99999),
sex: Mock.Random.cword('男女', 1),
city: Mock.Random.city(),
description: '-',
createTime: Mock.mock('@datetime'),
parentId,
children,
isParent: !!children.length
}
}
// 生成树
const rootNodes = Mock.mock({
'array|10-20': [
createNode
]
}).array
const getTreeData = function (nodes) {
let result = []
nodes.forEach(node => {
result.push({...node, parentId: null, children: getTreeData(node.children)});
})
return result
};
return getTreeData(rootNodes);
};
</script>
</body>
</html>