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 ...
随机推荐
- Bzoj1901 Dynamic Ranking
动态区间第k小 离散化后 那么每个点开一棵线段树(主席树)再套一个树状数组在外面 每次询问区间内的树的个数时 相当于进行了一次树状数组求区间和的操作,只是是把树状数组那个点看做主席树,对log棵主席树 ...
- 微信小程序天坑--图片汉字命名
图片用汉字命名的,在开发者工具中是显示的,但是,在真机的微信中,是不会显示的. 大写的尴尬,微信小程序开发者工具对于做微信的UI来说,就是一个天坑,在电脑上漂漂亮亮的,到手机上各种意想不到的情况.
- lftp 卡在 Making data connection 解决方法
用lftp连接到一个ftp服务器,执行ls命令结果一直Making data connection. google一下都说执行set ftp:ssl-allow no,但是实测无效. 上lftp官网看 ...
- datatable 多字段 排序;
没有找到datatable的排序方面运用案例,根据接口,自己实现 所以记录一二,小伙伴们有更好的方法,欢迎讨论 1.需求图 2.需求 1)默认 未开启 灰色下箭头 2)第一次点击 :启动排序,降序- ...
- linux 下oracle 11g静默安装(完整版)
1.操作系统及Oracle版本Linux版本:CentOS release 6.5Oracle版本:Oracle Database 11g Release 2 (11.2.0.1.0) for Lin ...
- Rotation Proposals
Rotation Proposals 论文Arbitrary-Oriented Scene Text Detection via Rotation Proposals 这篇论文提出了一个基于Faste ...
- IDEA jsp模板
> File > Settings- > File and Code Templates > Other >Jsp files >Jsp File.jsp < ...
- linux实验一 双系统安装
(一)首先来简要了解一些linux的概念! 1.发行版本和内核版本的区别与联系:linux发行版本是"内核版本+一系列挂载软件"的集合体,光是一个内核版本是无法当做操作系统运行的. ...
- NOIP2015 D2T3 洛谷2680 BZOJ4326 运输计划 解题报告
前言:个人认为这是历年NOIP中比较简单的最后一题了,因此将自己的思路与大家分享. 题目大意: 给一棵无根树,给出m条路径.允许将树上的一条边的权值改为0.求m条路径长度最大值的最小值.n,m< ...
- ubuntu下cmake 使用clang
安装llvm.clang sudo apt-get install llvm clang clang命令会在/usr/bin/clang cmake配置交叉编译链 建立linux.toolchain. ...