jstree的简单用法
一般我们用jstree主要实现树的形成,并且夹杂的邮件增删重命名刷新的功能
下面是我在项目中的运用,采用的是异步加载
$('#sensor_ul').data('jstree', false).empty();//先销毁清空
function getSensors(){
$("#sensor_ul").jstree({
"core" : {
"animation" : 0,
"check_callback" : true,
"themes" : {
"theme" : "classic",
"dots" : true,
"icons" : true,
"stripes" : true
},
'data':{
'url':function(node){
if(node.id === '#'){//异步加载
return root+"/jsPlumb1/getDeviceTreeRoot";
}else{
return root+"/jsPlumb1/getDeviceTreeChild/"+node.id;
}
},
'data':function (node){
if(node.id === '#'){
return{
'id':node.id
}
}else{
return{
'id':node.original.id,
'a_attr':node.original.a_attr 自定义属性放在这里或者li_attr,让后台给你返回来
};
}
}
}
},
"types" : {
"#" : {
"max_children" : 1,
"max_depth" : 10000,
"valid_children" : []
},
"deviceTreeDatasource":{
"icon": "assets/tree/chart_organisation.png",
"valid_children" : ['deviceTreeDatapoint']
},
"deviceTreeDatapoint":{
"icon": "assets/tree/Electricity_Error.png",
"valid_children" : []
}
},
"checkbox" : {
"keep_selected_style" : false,
"real_checkboxes" : true
},
"plugins" : [
"state", "search", "types", "wholerow","checkbox","contextmenu","search"
],
"contextmenu": {
"items": {
"create": null,
"ccp": null,
"remove": {
"label": "删除设备",
"icon": "assets/tree/action_delete.gif",
"action": function(data) {
layer.open({
content: '确定要删除此设备?删除后不可恢复。'
,btn: ['是', '取消']
,resize:false
,yes: function(index, layero){
layer.close(index);
var ref = $('#sensor_ul').jstree(true);//获得整个树
nodeidArr = ref.get_selected(); //获得所有选中节点,返回值为数组
$.ajax({
async: true,
type: 'post',
url:root+"/VirtualPoint/deleteVirtualUnit",
dataType: 'json',
data: {
nodeidArr:nodeidArr
},
success: function(data) {
// alert(typeof data.names);
if(data.names == null){
jQuery("#sensor_ul").jstree("refresh");
layer.msg("删除设备成功!",{icon:1,time:1500});
}else{
layer.msg(data.names+"设备删除失败!",{icon:5,time:1500});
}
}
});
},btn2: function(index, layero){
//按钮【按钮二】的回调
layer.close(index);
//return false 开启该代码可禁止点击该按钮关闭
},cancel: function(){
//右上角关闭回调
layer.close();
//return false 开启该代码可禁止点击该按钮关闭
}
})
}
},
"rename": {
"label": "重命名设备",
"icon": " assets/tree/edit.gif",
"action":function (data) {
var inst = $.jstree.reference(data.reference),
obj = inst.get_node(data.reference);
inst.edit(obj);
}
},
"refresh": {
"label": "刷新设备",
"icon": " assets/tree/arrow_refresh.png",
"action":function (data) {
jQuery("#sensor_ul").jstree("refresh");
}
},
}
}
});
$('#sensor_ul').on("rename_node.jstree",function(e,d){
var oldName = d.old;
var newName = d.text;
var nodeId = d.node.id;
var parentnodeId = d.node.parent;
var datapointId = d.node.a_attr.source;
$.ajax({
async: true,
type: 'post',
url:root+"/VirtualPoint/updateVirtualUnit",
dataType: 'json',
data: {
nodeId:nodeId,
datapointId:datapointId,
newName:newName
},
success: function(data) {
if(data.success == "1"){
layer.msg("重命名设备成功!",{icon:1,time:1500})
jQuery("#sensor_ul").jstree("#"+parentnodeId);
// jQuery("#sensor_ul").jstree("refresh");
}else if(data.success == "0_1"){
layer.msg("获取请求参数失败!",{icon:5,time:1500})
}else{
layer.msg("重命名失败!",{icon:5,time:1500})
}
}
});
});
$('#sensor_ul').on("after_open.jstree", function (e, data) { //节点被打开,并且动画加载完都显示
})
jstree的简单用法的更多相关文章
- jsTree 的简单用法--异步加载和刷新数据
首先这两个文件是必须要引用的,还有就是引用 jQuery 文件就不说了: <link href="/css/plugins/jsTree/style.min.css" rel ...
- CATransition(os开发之画面切换) 的简单用法
CATransition 的简单用法 //引进CATransition 时要添加包“QuartzCore.framework”,然后引进“#import <QuartzCore/QuartzCo ...
- jquery.validate.js 表单验证简单用法
引入jquery.validate.js插件以及Jquery,在最后加上这个插件的方法名来引用.$('form').validate(); <!DOCTYPE html PUBLIC " ...
- NSCharacterSet 简单用法
NSCharacterSet 简单用法 NSCharacterSet其实是许多字符或者数字或者符号的组合,在网络处理的时候会用到 NSMutableCharacterSet *base = [NSMu ...
- [转]Valgrind简单用法
[转]Valgrind简单用法 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian S ...
- Oracle的substr函数简单用法
substr(字符串,截取开始位置,截取长度) //返回截取的字 substr('Hello World',0,1) //返回结果为 'H' *从字符串第一个字符开始截取长度为1的字符串 subst ...
- Ext.Net学习笔记19:Ext.Net FormPanel 简单用法
Ext.Net学习笔记19:Ext.Net FormPanel 简单用法 FormPanel是一个常用的控件,Ext.Net中的FormPanel控件同样具有非常丰富的功能,在接下来的笔记中我们将一起 ...
- TransactionScope简单用法
记录TransactionScope简单用法,示例如下: void Test() { using (TransactionScope scope = new TransactionScope()) { ...
- WPF之Treeview控件简单用法
TreeView:表示显示在树结构中分层数据具有项目可展开和折叠的控件 TreeView 的内容是可以包含丰富内容的 TreeViewItem 控件,如 Button 和 Image 控件.TreeV ...
随机推荐
- 清橙A1212:剪枝
题面 清橙 Sol 一种新的树上\(DP\)姿势 从左往右按链\(DP\) 做法: 维护两个栈\(S1\),\(S2\) \(S1\)存当前的链 \(S2\)存分叉点以下要改的链 \(Dfs\),弄一 ...
- vue 父组件与子组件的通信
参考博客地址:http://www.cnblogs.com/okaychen/p/7674211.html,很详细!
- 【bzoj2820】GCD
Time Limit: 3000 ms Memory Limit: 256 MB description 神犇GJS虐完数论后给zzHGR出了一个数论题. 给定n,m,求1≤x≤n,1≤y≤m ...
- Scala编程快速入门系列(一)
目 录 一.Scala概述 二.Scala数据类型 三.Scala函数 四.Scala集合 五.Scala伴生对象 六.Scala trait 七.Actor 八.隐式转换与隐式参数 九.Sca ...
- JAVA线程sleep和wait方法区别
一. sleep 是线程类(Thread)的方法,导致此线程暂停执行指定时间,给执行机会给其他线程,但是监控状态依然保持,到时后会自动恢复,调用sleep 不会释放对象锁.由于没有释放对象锁,所以不能 ...
- 线段树 (区间查询最大 区间求和 区间加)带lazy
; struct Segment_tree { struct Node { int val,Max,lazy; ]; void init() { lazy=son[]=son[]=Size=val=M ...
- windows中安装redis
Redis是有名的NoSql数据库,一般Linux都会默认支持.但在Windows环境中, Windows的Redis安装包需要到以下GitHub链接找到.链接:https://github.com/ ...
- parted分区和挂载及非交互式操作
author : headsen chen date : 2017-11-17 09:45:36 个人原创,转载请注明作者,出处,否则依法追究法律责任 1,将磁盘上原有的分区删除掉: 进入:#pa ...
- java 多线程(总结)
今天看了几篇关于java多线程问题的文章,将他们的部分内容引过来总结下,也算是对java多线程这类问题的整理. 在多线程中,必须明白两个问题,一是多线程实现,二是代码同步. 在java中要想实现多线程 ...
- 教你快速打造PHP MVC框架
简介 MVC框架在现在的开发中相当流行,不论你使用的是JAVA,C#,PHP或者IOS,你肯定都会选择一款框架.虽然不能保证100%的开发语言都会使用框架,但是在PHP社区当中拥有最多数量的MVC框架 ...