feat(atree): 新增atree模块

This commit is contained in:
smallwei 2018-07-16 22:15:18 +08:00
parent 8dae2c5feb
commit 1b541568a0
6 changed files with 847 additions and 522 deletions

0
HARD Normal file
View File

144
examples/atree.html Normal file
View File

@ -0,0 +1,144 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<title>树模块 - layui</title>
<link rel="stylesheet" href="../src/css/layui.css">
<style>
body {
padding: 50px 100px;
}
</style>
</head>
<body>
<ul id="demo"></ul>
<script src="../src/layui.js"></script>
<script>
layui.use('atree', function() {
var tree = layui.atree({
elem: '#demo' //指定元素
,
check: 'checkbox' //勾选风格
,
skin: 'as' //设定皮肤
//,target: '_blank' //是否新选项卡打开比如节点返回href才有效
,
drag: true,
props:{
name: 'name',
id: 'id',
children:'children'
},
change:function(val){
console.group('change event')
console.log('Array')
console.log(val);
console.groupEnd()
},
click: function(item) { //点击节点回调
console.group('click event')
console.log('Object')
console.log(item);
console.groupEnd()
},
addClick:function(item,elem,add){
console.group('append event')
console.log('Object')
console.log(item);
console.log('dom')
console.log(elem);
console.log('dom add event')
var item ={
name: '测试节点'+new Date().getTime(),
id:-1
}
add(item)
console.groupEnd()
},
deleteClick:function(item,elem,done){
console.group('delete event')
console.log('Object')
console.log(item);
console.log('dom')
console.log(elem);
console.log('dom delete event')
done();
console.groupEnd()
},
nodes: [ //节点
{
name: '常用文件夹',
id: 1,
alias: 'changyong',
children: [{
name: '所有未读',
id: 11
//,href: 'http://www.layui.com/'
,
alias: 'weidu'
}, {
name: '置顶邮件',
id: 12
}, {
name: '标签邮件',
id: 13
}]
}, {
name: '我的邮箱',
id: 2,
spread: true,
children: [{
name: 'QQ邮箱',
id: 21,
spread: true,
children: [{
name: '收件箱',
id: 211,
children: [{
name: '所有未读',
id: 2111
}, {
name: '置顶邮件',
id: 2112
}, {
name: '标签邮件',
id: 2113
}]
}, {
name: '已发出的邮件',
id: 212
}, {
name: '垃圾邮件',
id: 213
}]
}, {
name: '阿里云邮',
id: 22,
children: [{
name: '收件箱',
id: 221
}, {
name: '已发出的邮件',
id: 222
}, {
name: '垃圾邮件',
id: 223
}]
}]
}
]
});
});
</script>
</body>
</html>

View File

@ -1,148 +1,113 @@
<!DOCTYPE html> <!DOCTYPE html>
<html> <html>
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
<title>树模块 - layui</title> <title>树模块 - layui</title>
<link rel="stylesheet" href="../src/css/layui.css"> <link rel="stylesheet" href="../src/css/layui.css">
<style> <style>
body { body{padding: 50px 100px;}
padding: 50px 100px; </style>
}
</style>
</head> </head>
<body> <body>
<ul id="demo"></ul> <ul id="demo"></ul>
<ul id="demo1" style="margin-top: 50px;"></ul> <ul id="demo1" style="margin-top: 50px;"></ul>
<script src="../src/layui.js"></script> <script src="../src/layui.js"></script>
<script> <script>
layui.use('tree', function() {
layui.use('tree', function(){
var tree = layui.tree({ var tree = layui.tree({
elem: '#demo' //指定元素 elem: '#demo' //指定元素
, //,check: 'checkbox' //勾选风格
check: 'checkbox' //勾选风格 ,skin: 'as' //设定皮肤
,
skin: 'as' //设定皮肤
//,target: '_blank' //是否新选项卡打开比如节点返回href才有效 //,target: '_blank' //是否新选项卡打开比如节点返回href才有效
, ,drag: true
drag: true, ,click: function(item){ //点击节点回调
props:{ console.log(item)
name: 'name',
id: 'id',
children:'children'
},
change:function(val){
console.group('change event')
console.log('Array')
console.log(val);
console.groupEnd()
},
click: function(item) { //点击节点回调
console.group('click event')
console.log('Object')
console.log(item);
console.groupEnd()
},
addClick:function(item,elem,add){
console.group('append event')
console.log('Object')
console.log(item);
console.log('dom')
console.log(elem);
console.log('dom add event')
var item ={
name: '测试节点'+new Date().getTime(),
id:-1
} }
add(item) ,nodes: [ //节点
console.groupEnd()
},
deleteClick:function(item,elem,done){
console.group('delete event')
console.log('Object')
console.log(item);
console.log('dom')
console.log(elem);
console.log('dom delete event')
done();
console.groupEnd()
},
nodes: [ //节点
{ {
name: '常用文件夹', name: '常用文件夹'
id: 1, ,id: 1
alias: 'changyong', ,alias: 'changyong'
children: [{ ,children: [
name: '所有未读', {
id: 11 name: '所有未读'
,id: 11
//,href: 'http://www.layui.com/' //,href: 'http://www.layui.com/'
, ,alias: 'weidu'
alias: 'weidu'
}, { }, {
name: '置顶邮件', name: '置顶邮件'
id: 12 ,id: 12
}, { }, {
name: '标签邮件', name: '标签邮件'
id: 13 ,id: 13
}] }
]
}, { }, {
name: '我的邮箱', name: '我的邮箱'
id: 2, ,id: 2
spread: true, ,spread: true
children: [{ ,children: [
name: 'QQ邮箱', {
id: 21, name: 'QQ邮箱'
spread: true, ,id: 21
children: [{ ,spread: true
name: '收件箱', ,children: [
id: 211, {
children: [{ name: '收件箱'
name: '所有未读', ,id: 211
id: 2111 ,children: [
{
name: '所有未读'
,id: 2111
}, { }, {
name: '置顶邮件', name: '置顶邮件'
id: 2112 ,id: 2112
}, { }, {
name: '标签邮件', name: '标签邮件'
id: 2113 ,id: 2113
}] }
]
}, { }, {
name: '已发出的邮件', name: '已发出的邮件'
id: 212 ,id: 212
}, { }, {
name: '垃圾邮件', name: '垃圾邮件'
id: 213 ,id: 213
}] }
]
}, { }, {
name: '阿里云邮', name: '阿里云邮'
id: 22, ,id: 22
children: [{ ,children: [
name: '收件箱', {
id: 221 name: '收件箱'
,id: 221
}, { }, {
name: '已发出的邮件', name: '已发出的邮件'
id: 222 ,id: 222
}, { }, {
name: '垃圾邮件', name: '垃圾邮件'
id: 223 ,id: 223
}] }
}] ]
}
]
} }
] ]
}); });
//生成一个模拟树 //生成一个模拟树
var createTree = function(node, start) { var createTree = function(node, start){
node = node || function() { node = node || function(){
var arr = []; var arr = [];
for (var i = 1; i < 10; i++) { for(var i = 1; i < 10; i++){
arr.push({ arr.push({
name: i.toString().replace(/(\d)/, '$1$1$1$1$1$1$1$1$1') name: i.toString().replace(/(\d)/, '$1$1$1$1$1$1$1$1$1')
}); });
@ -150,11 +115,13 @@
return arr; return arr;
}(); }();
start = start || 1; start = start || 1;
layui.each(node, function(index, item) { layui.each(node, function(index, item){
if (start < 10 && index < 9) { if(start < 10 && index < 9){
var child = [{ var child = [
{
name: (1 + index + start).toString().replace(/(\d)/, '$1$1$1$1$1$1$1$1$1') name: (1 + index + start).toString().replace(/(\d)/, '$1$1$1$1$1$1$1$1$1')
}]; }
];
node[index].children = child; node[index].children = child;
createTree(child, index + start + 1); createTree(child, index + start + 1);
} }
@ -164,19 +131,17 @@
layui.tree({ layui.tree({
elem: '#demo1' //指定元素 elem: '#demo1' //指定元素
, ,nodes: createTree()
nodes: createTree()
}); });
}); });
</script> </script>
<!--<pre class="layui-code"> <pre class="layui-code">
# layui.tree-v2 备忘 # layui.tree-v2 备忘
* check参数 - checkbox、radio的支持 * check参数 - checkbox、radio的支持
* 拖拽的支持 * 拖拽的支持
</pre>--> </pre>
</body> </body>
</html> </html>

360
src/lay/modules/atree.js Normal file
View File

@ -0,0 +1,360 @@
/**
@Namelayui.atree2.0 树组件
@Authorsmallwei
@LicenseMIT
*/
layui.define('jquery', function(exports) {
"use strict";
var $ = layui.$,
hint = layui.hint();
//勾选集合
var changeList = [];
//变量别名
var props ={
name: 'name',
id: 'id',
children:'children'
};
var enterSkin = 'layui-tree-enter',
Tree = function(options) {
this.options = options;
this.props = this.options.props || props;
this.nameKey = this.props.name || props.name;
this.idKey = this.props.id || props.id;
this.childrenKey = this.props.children || props.children;
};
//图标
var icon = {
arrow: ['&#xe623;', '&#xe625;'] //箭头
,
checkbox: ['&#xe68c;', '&#xe624;'] //复选框
,
leaf: '&#xe621;' //叶节点
};
//初始化
Tree.prototype.init = function(elem) {
var that = this;
elem.addClass('layui-box layui-tree'); //添加tree样式
if(that.options.skin) {
elem.addClass('layui-tree-skin-' + that.options.skin);
}
that.tree(elem);
that.on(elem);
};
//树节点解析
Tree.prototype.tree = function(elem, children) {
var that = this,
options = that.options
var nodes = children || options.nodes;
layui.each(nodes, function(index, item) {
var hasChild = item[that.childrenKey] && item[that.childrenKey].length > 0;
var ul = $('<ul class="' + (item.spread ? "layui-show" : "") + '"></ul>');
var li = that.getNode(item, hasChild);
//如果有子节点,则递归继续生成树
if(hasChild) {
li.append(ul);
that.tree(ul, item[that.childrenKey]);
}
//伸展节点
that.spread(li, item);
that.bindUlEvent(li, item);
elem.append(li);
});
};
//节点dom拼接
Tree.prototype.getDom = function() {
var that = this,
options = that.options
return {
spread: function(item, hasChild) {
return hasChild ? '<i class="layui-icon layui-tree-spread">' + (
item.spread ? icon.arrow[1] : icon.arrow[0]
) + '</i>' : '';
},
checkbox: function(item) {
return options.check ? (
'<i class="layui-icon layui-tree-check">' + (
options.check === 'checkbox' ? icon.checkbox[0] : (
options.check === 'radio' ? icon.radio[0] : ''
)
) + '</i>'
) : '';
},
node: function(item) {
return '<a href="' + (item.href || 'javascript:;') + '" ' + (
options.target && item.href ? 'target=\"' + options.target + '\"' : ''
) + '>' +
('<cite>' + (item[that.nameKey] || '未命名') + '</cite></a>')
},
menu: function(item) {
return '<div class="layui-tree-menu">' +
'<span class="layui-tree-add">Add</span>' +
'<span class="layui-tree-delete">Delete</span>' +
'</div>'
}
}
}
//获取树节点
Tree.prototype.getNode = function(item, hasChild) {
var that = this,
options = that.options
var dom = that.getDom();
var li = $(['<li ' + (item.spread ? 'data-spread="' + item.spread + '"' : '') +('data-id=' + item[that.idKey])+ '>'
//展开箭头
,
dom.spread(item, hasChild)
//复选框/单选框
,
dom.checkbox(item)
//节点
,
dom.node(item)
//菜单
,
dom.menu()
,
'</li>'
].join(''));
return li;
}
//父绑定事件
Tree.prototype.bindUlEvent = function(li, item) {
var that = this,
options = that.options
//触发点击节点回调
typeof options.click === 'function' && that.click(li, item);
//节点选择
typeof options.change === 'function' && options.check === 'checkbox' && that.checkbox(li, item);
//新增方法
typeof options.addClick === 'function' && that.add(li, item);
//删除方法
typeof options.deleteClick === 'function' && that.delete(li, item);
//拖拽节点
options.drag && that.drag(li, item);
}
//选中回调函数
Tree.prototype.change = function() {
var that = this,
options = that.options;
options.change(changeList);
},
//新增方法回调
Tree.prototype.add = function(elem, item) {
var that = this,
options = that.options;
var addBtn = elem.children('.layui-tree-menu').children('.layui-tree-add')
var arrow = elem.children('.layui-tree-spread')
var ul = elem.children('ul'),
a = elem.children('a');
var addEvent = function(e) {
layui.stope(e);
var _addEvent = {
add: function(itemAddObj) {
if(!ul[0]) {
ul = $('<ul class="layui-show"></ul>');
elem.append(ul);
}
if(!arrow[0]) {
arrow = $('<i class="layui-icon layui-tree-spread">' + icon.arrow[1] + '</i>');
elem.prepend(arrow);
that.spread(elem, item);
}
if(!elem.data('spread')) {
that.open(elem, ul, arrow)
}
var li = that.getNode(itemAddObj, false);
that.bindUlEvent(li, itemAddObj);
ul.append(li);
}
}
options.addClick(item, elem, _addEvent.add)
}
addBtn.on('click', addEvent);
}
//删除方法回调
Tree.prototype.delete = function(elem, item) {
var that = this,
options = that.options;
var deleteBtn = elem.children('.layui-tree-menu').children('.layui-tree-delete')
var ul = elem.children('ul'),
a = elem.children('a');
var deleteEvent = function(e) {
layui.stope(e);
var _deleteEvent = {
done: function() {
elem.html('');
}
}
options.deleteClick(item, elem, _deleteEvent.done)
}
deleteBtn.on('click', deleteEvent);
}
//点击节点回调
Tree.prototype.click = function(elem, item) {
var that = this,
options = that.options;
elem.children('a').on('click', function(e) {
layui.stope(e);
options.click(item)
});
};
//节点选择
Tree.prototype.checkbox = function(elem, item) {
var that = this,
options = that.options;
var checkbox = elem.children('.layui-tree-check')
var ul = elem.children('ul'),
a = elem.children('a');
var check = function() {
var index = layui.findObj(changeList, item);
if(elem.data('check')) {
elem.data('check', null)
checkbox.html(icon.checkbox[0]);
} else {
elem.data('check', true);
checkbox.html(icon.checkbox[1]);
}
if(index === -1) {
changeList.push(item);
} else {
changeList.splice(index, 1);
}
that.change();
}
checkbox.on('click', check);
};
//伸展节点
Tree.prototype.spread = function(elem, item) {
var that = this,
options = that.options;
var arrow = elem.children('.layui-tree-spread')
var ul = elem.children('ul'),
a = elem.children('a');
//如果没有子节点,则不执行
if(!ul[0]) return;
arrow.on('click', function() {
that.open(elem, ul, arrow)
});
}
//打开节点
Tree.prototype.open = function(elem, ul, arrow) {
if(elem.data('spread')) {
elem.data('spread', null)
ul.removeClass('layui-show');
arrow.html(icon.arrow[0]);
} else {
elem.data('spread', true);
ul.addClass('layui-show');
arrow.html(icon.arrow[1]);
}
};
//通用事件
Tree.prototype.on = function(elem) {
var that = this,
options = that.options;
var dragStr = 'layui-tree-drag';
//屏蔽选中文字
elem.find('i').on('selectstart', function(e) {
return false
});
//拖拽
if(options.drag) {
$(document).on('mousemove', function(e) {
var move = that.move;
if(move.from) {
var to = move.to,
treeMove = $('<div class="layui-box ' + dragStr + '"></div>');
e.preventDefault();
$('.' + dragStr)[0] || $('body').append(treeMove);
var dragElem = $('.' + dragStr)[0] ? $('.' + dragStr) : treeMove;
(dragElem).addClass('layui-show').html(move.from.elem.children('a').html());
dragElem.css({
left: e.pageX + 10,
top: e.pageY + 10
})
}
}).on('mouseup', function() {
var move = that.move;
if(move.from) {
move.from.elem.children('a').removeClass(enterSkin);
move.to && move.to.elem.children('a').removeClass(enterSkin);
that.move = {};
$('.' + dragStr).remove();
}
});
}
};
//拖拽节点
Tree.prototype.move = {};
Tree.prototype.drag = function(elem, item) {
var that = this,
options = that.options;
var a = elem.children('a'),
mouseenter = function() {
var othis = $(this),
move = that.move;
if(move.from) {
move.to = {
item: item,
elem: elem
};
othis.addClass(enterSkin);
}
};
a.on('mousedown', function() {
var move = that.move
move.from = {
item: item,
elem: elem
};
});
a.on('mouseenter', mouseenter).on('mousemove', mouseenter)
.on('mouseleave', function() {
var othis = $(this),
move = that.move;
if(move.from) {
delete move.to;
othis.removeClass(enterSkin);
}
});
};
//暴露接口
exports('atree', function(options) {
var tree = new Tree(options = options || {});
var elem = $(options.elem);
if(!elem[0]) {
return hint.error('layui.tree 没有找到' + options.elem + '元素');
}
tree.init(elem);
});
});

View File

@ -1,309 +1,168 @@
/** /**
@Namelayui.tree2.0 树组件 @Namelayui.tree 树组件
@Authorsmallwei @Author贤心
@LicenseMIT @LicenseMIT
*/ */
layui.define('jquery', function(exports) {
layui.define('jquery', function(exports){
"use strict"; "use strict";
var $ = layui.$, var $ = layui.$
hint = layui.hint(); ,hint = layui.hint();
//勾选集合
var changeList = []; var enterSkin = 'layui-tree-enter', Tree = function(options){
//变量别名 this.options = options;
var props ={
name: 'name',
id: 'id',
children:'children'
}; };
var enterSkin = 'layui-tree-enter',
Tree = function(options) {
this.options = options;
this.props = this.options.props || props;
this.nameKey = this.props.name || props.name;
this.idKey = this.props.id || props.id;
this.childrenKey = this.props.children || props.children;
};
//图标 //图标
var icon = { var icon = {
arrow: ['&#xe623;', '&#xe625;'] //箭头 arrow: ['&#xe623;', '&#xe625;'] //箭头
, ,checkbox: ['&#xe626;', '&#xe627;'] //复选框
checkbox: ['&#xe68c;', '&#xe624;'] //复选框 ,radio: ['&#xe62b;', '&#xe62a;'] //单选框
, ,branch: ['&#xe622;', '&#xe624;'] //父节点
leaf: '&#xe621;' //叶节点 ,leaf: '&#xe621;' //叶节点
}; };
//初始化 //初始化
Tree.prototype.init = function(elem) { Tree.prototype.init = function(elem){
var that = this; var that = this;
elem.addClass('layui-box layui-tree'); //添加tree样式 elem.addClass('layui-box layui-tree'); //添加tree样式
if(that.options.skin) { if(that.options.skin){
elem.addClass('layui-tree-skin-' + that.options.skin); elem.addClass('layui-tree-skin-'+ that.options.skin);
} }
that.tree(elem); that.tree(elem);
that.on(elem); that.on(elem);
}; };
//树节点解析 //树节点解析
Tree.prototype.tree = function(elem, children) { Tree.prototype.tree = function(elem, children){
var that = this, var that = this, options = that.options
options = that.options
var nodes = children || options.nodes; var nodes = children || options.nodes;
layui.each(nodes, function(index, item) { layui.each(nodes, function(index, item){
var hasChild = item[that.childrenKey] && item[that.childrenKey].length > 0; var hasChild = item.children && item.children.length > 0;
var ul = $('<ul class="' + (item.spread ? "layui-show" : "") + '"></ul>'); var ul = $('<ul class="'+ (item.spread ? "layui-show" : "") +'"></ul>');
var li = that.getNode(item, hasChild); var li = $(['<li '+ (item.spread ? 'data-spread="'+ item.spread +'"' : '') +'>'
//如果有子节点,则递归继续生成树 //展开箭头
if(hasChild) { ,function(){
li.append(ul); return hasChild ? '<i class="layui-icon layui-tree-spread">'+ (
that.tree(ul, item[that.childrenKey]);
}
//伸展节点
that.spread(li, item);
that.bindUlEvent(li, item);
elem.append(li);
});
};
//节点dom拼接
Tree.prototype.getDom = function() {
var that = this,
options = that.options
return {
spread: function(item, hasChild) {
return hasChild ? '<i class="layui-icon layui-tree-spread">' + (
item.spread ? icon.arrow[1] : icon.arrow[0] item.spread ? icon.arrow[1] : icon.arrow[0]
) + '</i>' : ''; ) +'</i>' : '';
}, }()
checkbox: function(item) {
//复选框/单选框
,function(){
return options.check ? ( return options.check ? (
'<i class="layui-icon layui-tree-check">' + ( '<i class="layui-icon layui-tree-check">'+ (
options.check === 'checkbox' ? icon.checkbox[0] : ( options.check === 'checkbox' ? icon.checkbox[0] : (
options.check === 'radio' ? icon.radio[0] : '' options.check === 'radio' ? icon.radio[0] : ''
) )
) + '</i>' ) +'</i>'
) : ''; ) : '';
}, }()
node: function(item) {
return '<a href="' + (item.href || 'javascript:;') + '" ' + (
options.target && item.href ? 'target=\"' + options.target + '\"' : ''
) + '>' +
('<cite>' + (item[that.nameKey] || '未命名') + '</cite></a>')
},
menu: function(item) {
return '<div class="layui-tree-menu">' +
'<span class="layui-tree-add">Add</span>' +
'<span class="layui-tree-delete">Delete</span>' +
'</div>'
}
}
}
//获取树节点
Tree.prototype.getNode = function(item, hasChild) {
var that = this,
options = that.options
var dom = that.getDom();
var li = $(['<li ' + (item.spread ? 'data-spread="' + item.spread + '"' : '') +('data-id=' + item[that.idKey])+ '>'
//展开箭头
,
dom.spread(item, hasChild)
//复选框/单选框
,
dom.checkbox(item)
//节点 //节点
, ,function(){
dom.node(item) return '<a href="'+ (item.href || 'javascript:;') +'" '+ (
//菜单 options.target && item.href ? 'target=\"'+ options.target +'\"' : ''
, ) +'>'
dom.menu() + ('<i class="layui-icon layui-tree-'+ (hasChild ? "branch" : "leaf") +'">'+ (
, hasChild ? (
'</li>' item.spread ? icon.branch[1] : icon.branch[0]
].join('')); ) : icon.leaf
return li; ) +'</i>') //节点图标
+ ('<cite>'+ (item.name||'未命名') +'</cite></a>');
}()
,'</li>'].join(''));
//如果有子节点,则递归继续生成树
if(hasChild){
li.append(ul);
that.tree(ul, item.children);
} }
//父绑定事件 elem.append(li);
Tree.prototype.bindUlEvent = function(li, item) {
var that = this,
options = that.options
//触发点击节点回调 //触发点击节点回调
typeof options.click === 'function' && that.click(li, item); typeof options.click === 'function' && that.click(li, item);
//节点选择 //伸展节点
typeof options.change === 'function' && options.check === 'checkbox' && that.checkbox(li, item); that.spread(li, item);
//新增方法
typeof options.addClick === 'function' && that.add(li, item);
//删除方法
typeof options.deleteClick === 'function' && that.delete(li, item);
//拖拽节点 //拖拽节点
options.drag && that.drag(li, item); options.drag && that.drag(li, item);
} });
};
//选中回调函数
Tree.prototype.change = function() {
var that = this,
options = that.options;
options.change(changeList);
},
//新增方法回调
Tree.prototype.add = function(elem, item) {
var that = this,
options = that.options;
var addBtn = elem.children('.layui-tree-menu').children('.layui-tree-add')
var arrow = elem.children('.layui-tree-spread')
var ul = elem.children('ul'),
a = elem.children('a');
var addEvent = function(e) {
layui.stope(e);
var _addEvent = {
add: function(itemAddObj) {
if(!ul[0]) {
ul = $('<ul class="layui-show"></ul>');
elem.append(ul);
}
if(!arrow[0]) {
arrow = $('<i class="layui-icon layui-tree-spread">' + icon.arrow[1] + '</i>');
elem.prepend(arrow);
that.spread(elem, item);
}
if(!elem.data('spread')) {
that.open(elem, ul, arrow)
}
var li = that.getNode(itemAddObj, false);
that.bindUlEvent(li, itemAddObj);
ul.append(li);
}
}
options.addClick(item, elem, _addEvent.add)
}
addBtn.on('click', addEvent);
}
//删除方法回调
Tree.prototype.delete = function(elem, item) {
var that = this,
options = that.options;
var deleteBtn = elem.children('.layui-tree-menu').children('.layui-tree-delete')
var ul = elem.children('ul'),
a = elem.children('a');
var deleteEvent = function(e) {
layui.stope(e);
var _deleteEvent = {
done: function() {
elem.html('');
}
}
options.deleteClick(item, elem, _deleteEvent.done)
}
deleteBtn.on('click', deleteEvent);
}
//点击节点回调 //点击节点回调
Tree.prototype.click = function(elem, item) { Tree.prototype.click = function(elem, item){
var that = this, var that = this, options = that.options;
options = that.options; elem.children('a').on('click', function(e){
elem.children('a').on('click', function(e) {
layui.stope(e); layui.stope(e);
options.click(item) options.click(item)
}); });
}; };
//节点选择
Tree.prototype.checkbox = function(elem, item) {
var that = this,
options = that.options;
var checkbox = elem.children('.layui-tree-check')
var ul = elem.children('ul'),
a = elem.children('a');
var check = function() {
var index = layui.findObj(changeList, item);
if(elem.data('check')) {
elem.data('check', null)
checkbox.html(icon.checkbox[0]);
} else {
elem.data('check', true);
checkbox.html(icon.checkbox[1]);
}
if(index === -1) {
changeList.push(item);
} else {
changeList.splice(index, 1);
}
that.change();
}
checkbox.on('click', check);
};
//伸展节点 //伸展节点
Tree.prototype.spread = function(elem, item) { Tree.prototype.spread = function(elem, item){
var that = this, var that = this, options = that.options;
options = that.options;
var arrow = elem.children('.layui-tree-spread') var arrow = elem.children('.layui-tree-spread')
var ul = elem.children('ul'), var ul = elem.children('ul'), a = elem.children('a');
a = elem.children('a');
//如果没有子节点,则不执行
if(!ul[0]) return;
arrow.on('click', function() {
that.open(elem, ul, arrow)
});
}
//打开节点 //执行伸展
Tree.prototype.open = function(elem, ul, arrow) { var open = function(){
if(elem.data('spread')) { if(elem.data('spread')){
elem.data('spread', null) elem.data('spread', null)
ul.removeClass('layui-show'); ul.removeClass('layui-show');
arrow.html(icon.arrow[0]); arrow.html(icon.arrow[0]);
a.find('.layui-icon').html(icon.branch[0]);
} else { } else {
elem.data('spread', true); elem.data('spread', true);
ul.addClass('layui-show'); ul.addClass('layui-show');
arrow.html(icon.arrow[1]); arrow.html(icon.arrow[1]);
a.find('.layui-icon').html(icon.branch[1]);
} }
}; };
//如果没有子节点,则不执行
if(!ul[0]) return;
arrow.on('click', open);
a.on('dblclick', open);
}
//通用事件 //通用事件
Tree.prototype.on = function(elem) { Tree.prototype.on = function(elem){
var that = this, var that = this, options = that.options;
options = that.options;
var dragStr = 'layui-tree-drag'; var dragStr = 'layui-tree-drag';
//屏蔽选中文字 //屏蔽选中文字
elem.find('i').on('selectstart', function(e) { elem.find('i').on('selectstart', function(e){
return false return false
}); });
//拖拽 //拖拽
if(options.drag) { if(options.drag){
$(document).on('mousemove', function(e) { $(document).on('mousemove', function(e){
var move = that.move; var move = that.move;
if(move.from) { if(move.from){
var to = move.to, var to = move.to, treeMove = $('<div class="layui-box '+ dragStr +'"></div>');
treeMove = $('<div class="layui-box ' + dragStr + '"></div>');
e.preventDefault(); e.preventDefault();
$('.' + dragStr)[0] || $('body').append(treeMove); $('.' + dragStr)[0] || $('body').append(treeMove);
var dragElem = $('.' + dragStr)[0] ? $('.' + dragStr) : treeMove; var dragElem = $('.' + dragStr)[0] ? $('.' + dragStr) : treeMove;
(dragElem).addClass('layui-show').html(move.from.elem.children('a').html()); (dragElem).addClass('layui-show').html(move.from.elem.children('a').html());
dragElem.css({ dragElem.css({
left: e.pageX + 10, left: e.pageX + 10
top: e.pageY + 10 ,top: e.pageY + 10
}) })
} }
}).on('mouseup', function() { }).on('mouseup', function(){
var move = that.move; var move = that.move;
if(move.from) { if(move.from){
move.from.elem.children('a').removeClass(enterSkin); move.from.elem.children('a').removeClass(enterSkin);
move.to && move.to.elem.children('a').removeClass(enterSkin); move.to && move.to.elem.children('a').removeClass(enterSkin);
that.move = {}; that.move = {};
@ -315,33 +174,29 @@ layui.define('jquery', function(exports) {
//拖拽节点 //拖拽节点
Tree.prototype.move = {}; Tree.prototype.move = {};
Tree.prototype.drag = function(elem, item) { Tree.prototype.drag = function(elem, item){
var that = this, var that = this, options = that.options;
options = that.options; var a = elem.children('a'), mouseenter = function(){
var a = elem.children('a'), var othis = $(this), move = that.move;
mouseenter = function() { if(move.from){
var othis = $(this),
move = that.move;
if(move.from) {
move.to = { move.to = {
item: item, item: item
elem: elem ,elem: elem
}; };
othis.addClass(enterSkin); othis.addClass(enterSkin);
} }
}; };
a.on('mousedown', function() { a.on('mousedown', function(){
var move = that.move var move = that.move
move.from = { move.from = {
item: item, item: item
elem: elem ,elem: elem
}; };
}); });
a.on('mouseenter', mouseenter).on('mousemove', mouseenter) a.on('mouseenter', mouseenter).on('mousemove', mouseenter)
.on('mouseleave', function() { .on('mouseleave', function(){
var othis = $(this), var othis = $(this), move = that.move;
move = that.move; if(move.from){
if(move.from) {
delete move.to; delete move.to;
othis.removeClass(enterSkin); othis.removeClass(enterSkin);
} }
@ -349,11 +204,11 @@ layui.define('jquery', function(exports) {
}; };
//暴露接口 //暴露接口
exports('tree', function(options) { exports('tree', function(options){
var tree = new Tree(options = options || {}); var tree = new Tree(options = options || {});
var elem = $(options.elem); var elem = $(options.elem);
if(!elem[0]) { if(!elem[0]){
return hint.error('layui.tree 没有找到' + options.elem + '元素'); return hint.error('layui.tree 没有找到'+ options.elem +'元素');
} }
tree.init(elem); tree.init(elem);
}); });

View File

@ -56,6 +56,7 @@
,layedit: 'modules/layedit' //富文本编辑器 ,layedit: 'modules/layedit' //富文本编辑器
,form: 'modules/form' //表单集 ,form: 'modules/form' //表单集
,upload: 'modules/upload' //上传 ,upload: 'modules/upload' //上传
,atree: 'modules/atree' //新树结构
,tree: 'modules/tree' //树结构 ,tree: 'modules/tree' //树结构
,table: 'modules/table' //表格 ,table: 'modules/table' //表格
,element: 'modules/element' //常用元素操作 ,element: 'modules/element' //常用元素操作