mirror of https://github.com/layui/layui
				
				
				
			
		
			
				
	
	
		
			115 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			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>
 |