一般我们用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的简单用法的更多相关文章

  1. jsTree 的简单用法--异步加载和刷新数据

    首先这两个文件是必须要引用的,还有就是引用 jQuery 文件就不说了: <link href="/css/plugins/jsTree/style.min.css" rel ...

  2. CATransition(os开发之画面切换) 的简单用法

    CATransition 的简单用法 //引进CATransition 时要添加包“QuartzCore.framework”,然后引进“#import <QuartzCore/QuartzCo ...

  3. jquery.validate.js 表单验证简单用法

    引入jquery.validate.js插件以及Jquery,在最后加上这个插件的方法名来引用.$('form').validate(); <!DOCTYPE html PUBLIC " ...

  4. NSCharacterSet 简单用法

    NSCharacterSet 简单用法 NSCharacterSet其实是许多字符或者数字或者符号的组合,在网络处理的时候会用到 NSMutableCharacterSet *base = [NSMu ...

  5. [转]Valgrind简单用法

    [转]Valgrind简单用法 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian S ...

  6. Oracle的substr函数简单用法

    substr(字符串,截取开始位置,截取长度) //返回截取的字 substr('Hello World',0,1) //返回结果为 'H'  *从字符串第一个字符开始截取长度为1的字符串 subst ...

  7. Ext.Net学习笔记19:Ext.Net FormPanel 简单用法

    Ext.Net学习笔记19:Ext.Net FormPanel 简单用法 FormPanel是一个常用的控件,Ext.Net中的FormPanel控件同样具有非常丰富的功能,在接下来的笔记中我们将一起 ...

  8. TransactionScope简单用法

    记录TransactionScope简单用法,示例如下: void Test() { using (TransactionScope scope = new TransactionScope()) { ...

  9. WPF之Treeview控件简单用法

    TreeView:表示显示在树结构中分层数据具有项目可展开和折叠的控件 TreeView 的内容是可以包含丰富内容的 TreeViewItem 控件,如 Button 和 Image 控件.TreeV ...

随机推荐

  1. NOIWC2018滚粗记

    Day0 \(THUWC\)刚刚结束..顺利的滚粗了 Day1 整理一下自己咸鱼的心 下午到学校坐车出发 这次队伍浩大THUWC只有4个 又到了雅礼洋湖这个地方 路上突然多了许多有关\(NOI\)的标 ...

  2. 图文详解AO打印(标准模式)

    一.概述   AO打印是英文Active-Online Print的简称,也称主动在线打印.打印前支持AO通讯协议的AO打印机(购买地址>>)首先通过普通网络与C-Lodop服务保持在线链 ...

  3. 接触vsto,开发word插件的利器

    研究word插件有一段时间了,现在该是总结的时候了. 首先咱们来了解下什么是vsto?所谓vsto,就是vs面向office提供的一个开发平台.一个开发平台至少包含两个要素:开发工具(sdk)和运行环 ...

  4. asp.net core 五 SignalR 负载均衡

           SignalR : Web中的实时功能实现,所谓实时功能,就是所连接的客户端变的可用时,服务端能实时的推送内容到客户端,而不是被动的等待客户端的请求.Asp.net SignalR 源码 ...

  5. .NET Core开源API网关 – Ocelot中文文档

    Ocelot是一个用.NET Core实现并且开源的API网关,它功能强大,包括了:路由.请求聚合.服务发现.认证.鉴权.限流熔断.并内置了负载均衡器与Service Fabric.Butterfly ...

  6. 进程优化工具Process Lasso Pro 8.4官方版+激活破解方法

    Process Lasso是一款来自美国的系统进程优化工具,基于特殊算法动态调整进程的优先级别,通过合理的设置进程优先级来实现降低系统负担的功能.可有效避免蓝 屏.假死.进程停止响应.进程占用 CPU ...

  7. LOOKUP函数入门

    2018-02-11  作者:ExcelHome  阅读:22045次       转载请注明来源"ExcelHome"并保留原文链接.固定链接:http://www.excelh ...

  8. leetCode:461 汉明距离

    汉明距离 两个整数之间的汉明距离指的是这两个数字对应二进制位不同的位置的数目. 给出两个整数 x 和 y,计算它们之间的汉明距离. 思路: 当看到"对应二进制位不同的位置的数目"这 ...

  9. 1-1hibernate数据库操作基础

    一.纯原始数据库连接详见http://www.cnblogs.com/lukelook/p/7845757.html 1.Class.forName("oracle.jdbc.driver. ...

  10. Java爬虫爬取网站电影下载链接

    之前有看过一段时间爬虫,了解了爬虫的原理,以及一些实现的方法,本项目完成于半年前,一直放在那里,现在和大家分享出来. 网络爬虫简单的原理就是把程序想象成为一个小虫子,一旦进去了一个大门,这个小虫子就像 ...