最近的项目用到了jstree,因为对官方文档理解不充分,所以很多功能都是在网站上搜索再进行使用的。(我只是大自然的搬运工)

  1. 对每一级的节点,右键后出现不同的结果。

在jstree中右键是由 contextmenu 实现的,所以我们需要自定义它。在这之前要在 plugins 中添加它。"plugins": ["contextmenu"]。

然后定义个函数

    function contextItem(node) {
let items = {
'item1': {
"增加地点": {
"label": "增加地点",
"action": function (data) {
let inst = jQuery.jstree.reference(data.reference),
obj = inst.get_node(data.reference);
inst.create_node(obj, {}, "last", function (new_node) {
inst.edit(new_node); });
}
}
},
'item2': {
"删除地点": {
"label": "删除地点",
"action": function (data) {
let inst = jQuery.jstree.reference(data.reference),
obj = inst.get_node(data.reference);
if (confirm("确定要删除此菜单?删除后不可恢复。")) {
inst.delete_node(obj);
}
}
},
"修改地点": {
"label": "修改地点",
"action": function (data) {
let inst = jQuery.jstree.reference(data.reference),
obj = inst.get_node(data.reference);
inst.edit(obj);
}
}
},
'item3': {
"create": null,
"rename": null,
"remove": null,
"ccp": null
}
};
if (node.type === '1_level') {
items = items.item1;
} else if (node.type === '2_level') {
items = items.item2;
} else {
items = items.item1;
}
// console.log(node.parent.length);
return items;
}

最后只要把定义好的函数引用在contextmenu中就好了。

 "contextmenu": {
"items": contextItem,
},

2.实现每个节点懒加载(点到相应的节点才会发送ajax到后台,获取相应数据)。如下图

在jstree中

core:{
data:DataLoader
}

定义了DataLoader函数。

function DataLoader(node, render) {
if (node.id === '#') { // 对于根节点来说,加载一级的地区目录
render(FakeAjaxLoadLevel1())
} else if (node.data) { //判断依据可以用户自定义
switch (node.data.level) {
case 1:
render(FakeAjaxLoadLevel2(node.text)); // 对于一级的地区目录来说,加载相应的市级
break;
case 2:
render(FakeAjaxLoadLevel3(node.text)); // 对于二级的市级来说,加载相应的辖区
break;
}
}
}

每一节点的函数返回jstree中所需的属性,以第一级为例

function FakeAjaxLoadLevel1() {
return [
{
text: '华东地区', id: 1, children: true,
data: {
level: 1
}
},
{
text: '华中地区', id: 2, children: true,
data: {
level: 1
}
}
];
}

3.每一层节点使用不同的图标

types标签

 "types": {
"default": {
"icon": "fa fa-globe"
},
"2_level": {
"icon": "fa fa-home"
},
"3_level": {
"icon": "fa fa-flag"
},
}

只是把自己所遇到的jstree问题进行总结,持续更新ing.

jstree 学习的更多相关文章

  1. 【JSTREE】 复选框默认选中【总结】

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"% ...

  2. 基于Metronic的Bootstrap开发框架经验总结(2)--列表分页处理和插件JSTree的使用

    在上篇<基于Metronic的Bootstrap开发框架经验总结(1)-框架总览及菜单模块的处理>介绍了Bootstrap开发框架的一些基础性概括,包括总体界面效果,以及布局.菜单等内容, ...

  3. 如何系统地学习Node.js?

    转载自知乎:http://www.zhihu.com/question/21567720 ------------------------------------------------------- ...

  4. (转)基于Metronic的Bootstrap开发框架经验总结(2)--列表分页处理和插件JSTree的使用

    http://www.cnblogs.com/wuhuacong/p/4759564.html 在上篇<基于Metronic的Bootstrap开发框架经验总结(1)-框架总览及菜单模块的处理& ...

  5. 从直播编程到直播教育:LiveEdu.tv开启多元化的在线学习直播时代

    2015年9月,一个叫Livecoding.tv的网站在互联网上引起了编程界的注意.缘于Pingwest品玩的一位编辑在上网时无意中发现了这个网站,并写了一篇文章<一个比直播睡觉更奇怪的网站:直 ...

  6. Angular2学习笔记(1)

    Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...

  7. ABP入门系列(1)——学习Abp框架之实操演练

    作为.Net工地搬砖长工一名,一直致力于挖坑(Bug)填坑(Debug),但技术却不见长进.也曾热情于新技术的学习,憧憬过成为技术大拿.从前端到后端,从bootstrap到javascript,从py ...

  8. 消息队列——RabbitMQ学习笔记

    消息队列--RabbitMQ学习笔记 1. 写在前面 昨天简单学习了一个消息队列项目--RabbitMQ,今天趁热打铁,将学到的东西记录下来. 学习的资料主要是官网给出的6个基本的消息发送/接收模型, ...

  9. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

随机推荐

  1. ERP中通过自定义单打开流程图

    背景: AIO75系统中,制作流程图时选择所属模块,即可在对应模块的左侧列表展示流程图入口. 但在AIO5商务版中没有相关入口,故本文提供使用自定义菜单的方式挂出流程图. 具体步骤: 1.先去看一下是 ...

  2. 【深度学习系列】用PaddlePaddle和Tensorflow进行图像分类

    上个月发布了四篇文章,主要讲了深度学习中的"hello world"----mnist图像识别,以及卷积神经网络的原理详解,包括基本原理.自己手写CNN和paddlepaddle的 ...

  3. CCF考试认证模拟练习——数字排序

    #include<iostream>#include<algorithm>using namespace std;struct node //定义结构体{ int num;// ...

  4. 02-线性结构4 Pop Sequence

    题目 Sample Input: 5 7 5 1 2 3 4 5 6 7 3 2 1 7 5 6 4 7 6 5 4 3 2 1 5 6 4 3 7 2 1 1 7 6 5 4 3 2 Sample ...

  5. win下搭建python3+PyQt5+eric6环境

    一.安装python3 1.下载python3的安装包,默认安装即可,注意勾选 Add Python 3.6 to Path .但是这样默认安装的路径太长,不太方便找到,可选择定制安装,自己定义安装路 ...

  6. windows 下更新 npm 和 node

    原文链接 公司的新项目要启动了,需要使用 Angular 4.0,并且使用 webpack 工具进行打包.所以就需要安装 node.node 的安装很简单,在 node 的官网 nodejs.org  ...

  7. thinkphp中各字母代表的发放和具体实例

    hinkphp单字母函数使用指南A方法 A方法用于在内部实例化控制器,调用格式:A('[项目://][分组/]模块','控制器层名称') 最简单的用法: $User = A('User'); 复制代码 ...

  8. tomcat警告setting property 'debug' to '0' did not find a matching property

    在使用tomcat6.0版本结合myeclipse进行java web项目,运行程序显示setting property 'debug' to '0' did not find a matching ...

  9. php综合运用技术

    五.PHP综合应用 1.写出下列服务的用途和默认端口(新浪网技术部) ftp.ssh.http.telnet.https ftp:File Transfer Protocol,文件传输协议,是应用层的 ...

  10. Mecanim动画系统

    序言:Mecanim动画系统是Unity4.0之后退出的新版动画系统,非常适合人类动画系统.本文是作为自己的学习来讲解的, 可能会有些啰嗦,但尽量把自己的坑都为大家列出来,让大家理解透彻. 一.文件的 ...