layui/examples/tree.html

262 lines
6.0 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>树组件 - layui</title>
<meta name="renderer" content="webkit">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="format-detection" content="telephone=no">
<link rel="stylesheet" href="../src/css/layui.css" media="all">
<style>
body{padding: 100px;}
#test1,#test2{margin-bottom: 100px; width: 400px;}
</style>
</head>
<body>
<div class="layui-btn-container">
<button type="button" class="layui-btn" lay-demo="getChecked">获取选中数据</button>
<button type="button" class="layui-btn" lay-demo="setChecked">设置节点勾选</button>
<button type="button" class="layui-btn" lay-demo="reload">重载实例</button>
</div>
<div class="layui-form">
<div class="layui-form-item">
<label class="layui-form-label">表单内</label>
<div class="layui-input-block">
</div>
</div>
<div id="test1"></div>
<div id="test2"></div>
<script src="../src/layui.js"></script>
<script>
layui.use(['tree', 'layer', 'util'], function(){
var $ = layui.$
,tree = layui.tree
,layer = layui.layer
,util = layui.util
,index = 100;
//数据源
var data1 = [{
title: '一级1'
,id: 1
,children: [{
title: '二级1-1'
,id: 3
,href: 'https://www.layui.com/doc/'
,children: [{
title: '三级1-1-3'
,id: 23
,children: [{
title: '四级1-1-3-1'
,id: 24
,children: [{
title: '五级1-1-3-1-1'
,id: 30
},{
title: '五级1-1-3-1-2'
,id: 31
}]
}]
},{
title: '三级1-1-1'
,id: 7
,checked: true
,children: [{
title: '四级1-1-1-1'
,id: 15
//,checked: true
,href: 'https://www.layui.com/doc/base/infrastructure.html'
}]
},{
title: '三级1-1-2'
,id: 8
,children: [{
title: '四级1-1-2-1'
,id: 32
}]
}]
},{
title: '二级1-2'
,id: 4
,spread: true
,children: [{
title: '三级1-2-1'
,id: 9
,checked: true
,disabled: true
},{
title: '三级1-2-2'
,id: 10
}]
},{
title: '二级1-3'
,id: 20
,children: [{
title: '三级1-3-1'
,id: 21
},{
title: '三级1-3-2'
,id: 22
}]
}]
},{
title: '一级2'
,id: 2
,spread: true
,children: [{
title: '二级2-1'
,id: 5
,spread: true
,children: [{
title: '三级2-1-1'
,id: 11
},{
title: '三级2-1-2'
,id: 12
}]
},{
title: '二级2-2'
,id: 6
,checked: true
,children: [{
title: '三级2-2-1'
,id: 13
},{
title: '三级2-2-2'
,id: 14
,disabled: true
}]
}]
},{
title: '一级3'
,id: 16
,children: [{
title: '二级3-1'
,id: 17
,fixed: true
,children: [{
title: '三级3-1-1'
,id: 18
},{
title: '三级3-1-2'
,id: 19
}]
},{
title: '二级3-2'
,id: 27
,children: [{
title: '三级3-2-1'
,id: 28
},{
title: '三级3-2-2'
,id: 29
}]
}]
}];
//数据源
var data2 = [{
title: '控制台'
,id: '1000'
,spread: true
,checked: true
,children: [{
title: '概览'
,id: '1001'
,spread: true
,checked: true
},{
title: '域名'
,id: '1002'
,spread: true
,checked: true
}]
}]
tree.render({
elem: '#test1'
,data: data1
,id: 'demoId1'
,click: function(obj){
layer.msg(JSON.stringify(obj.data));
console.log(obj);
}
,oncheck: function(obj){
//console.log(obj);
}
,operate: function(obj){
var type = obj.type;
if(type == 'add'){
//ajax操作返回key值
return index++;
}else if(type == 'update'){
console.log(obj.elem.find('.layui-tree-txt').html());
}else if(type == 'del'){
console.log(obj);
};
}
,showCheckbox: true //是否显示复选框
,accordion: 0 //是否开启手风琴模式
,onlyIconControl: true //是否仅允许节点左侧图标控制展开收缩
,isJump: 0 //点击文案跳转地址
,edit: true //操作节点图标
});
//按钮事件
util.event('lay-demo', {
getChecked: function(othis){
var checkedData = tree.getChecked('demoId1');
layer.alert(JSON.stringify(checkedData), {shade:0});
console.log(checkedData);
}
,setChecked: function(){
tree.setChecked('demoId1', [1000, 1001, 1002]);
}
,reload: function(){
tree.reload('demoId1', {
});
}
});
tree.render({
elem: '#test2'
,data: data1
//,expandClick: false
,showLine: false //关闭连接线
,click: function(obj, state){
console.log(obj);
}
,oncheck: function(obj, checked, child){
if(checked){
console.log(obj[0]);
}
}
,onsearch: function(data, num){
console.log(num);
}
,dragstart: function(obj, parent){
console.log(obj, parent);
}
,dragend: function(state, obj, target){
console.log(state, obj, target);
}
});
});
</script>
</body>
</html>