现在需要将省市县区域这块搞成树状图的形状,由于项目使用的AngularJS+ABP+WebAPI各个模块之间数据传输形式是json格式,那么对于JsTree来说就方便很多了,只需要将json数据搞成我们JsTree需要的嵌套形式数据存储就可以了。

JsTree官方地址

https://github.com/vakata/jstree#the-required-json-format

这里面有操作JsTree的全部内容,只需要将里面的小例子看懂,基本就没问题。好的一点是那边有人家的练习,理解起来很给力,只需要运行即可。

注意下:需要引用相关的js文件。这个在github中作者说的很清楚了,我们直接进行操作就可以了。

HTML页面

需要指定的ID值,用来显示我们Js文件中数据。

      <div class="portlet-body">
<div id="areasTree"></div>
</div>

JS页面

        app.controller('AreasCtrl', function ($http, $scope, systemSetting) {
$http.get('api/areas/all').then(function (response) {
if (response.data) {
console.log(response.data);
$('#areasTree').jstree({
'core': {
'data': response.data, //返回的数据,数组
"themes": {
"dots": true, // no connecting dots between dots
"responsive": false //无响应
},
'multiple': false, //设置其为没有多选
'check_callback': true, //设置其true.可以进行文本的修改。
},
'types': { //这里就是图片的显示格式
"default": {
"icon": "fa fa-folder tree-item-icon-color icon-lg"
},
"file": {
"icon": "fa fa-file tree-item-icon-color icon-lg"
}
},
'plugins': [ //插件,下面是插件的功能
'types', //可以设置其图标,在上面的一样。
'contextmenu', //文本菜单
'wholerow', //
'sort', //分类
'unique' //独特----防止重复。(新添加的)
]
});
}
});
});

通过html的get方法我们可以从后台得到完整的json数据,如下:

接着我们就进行上面内容的讲解。

‘core’:核心区域,里面主要是数据和主题。我们业务逻辑也是在这里进行的。里面一些功能都有注释,可以自己看懂。

‘types’这里是 下面插件中的图片的展示,是我们前面标签的图片。

‘plugins’是插件区域。这里可以自定义插件。文档的下面就有例子。插件部分我们可以看到有以下几个。

  • types:设置图标,对应于上面的那个。
  • contextmenu:文本内容菜单,也就是说可以有右键的那些属性,增删改查。
  • sort:分类。
  • unique:防止重复。
  • dnd:可以移动标签。

这样的特性还有很多,文档中都有。这里需要注意到contextmenu和dnd,这两个我们需要在core中设置其’check_callback’:true;这样才能确保可以操作和移动标签。

实现效果

下面是通过后台提供json数据,得到的树状图样式。

既然我们已经设置了contextmenu那么就意味着现在就有了右键功能,如下

那么如何才能响应这样操作,比如我点击新增,我是如何获取这些数据,如何将其发送到后台呢。

实现右键操作的响应

我们界面上的东西出来了,那么如何才能实现响应了。我们发现在官方文档中有下面的一句话。

"core.check_callback" can also be set to a function, that will be invoked every time a modification is about to happen (or when jstree needs to check if a modification is possible). If you return true the operation will be allowed, a value of falsemeans it will not be allowed. The possible operation you can expect are create_node, rename_node, delete_node, move_nodeand copy_node. The more parameter will contain various information provided by the plugin that is invoking the check. For example the DND plugin will provide an object containing information about the move or copy operation that is being checked - is it a multi tree operation, which node is currently hovered, where the insert arrow is pointing - before, after or inside, etc.

其实大概的意思就是说我们可以通过这里的匿名函数来进行设置,看到底我们在前端选择的是那个操作。

           'check_callback': function (operation, node, parent, position, more)       {          
              if (operation === 'create_node') {
console.log(parent.text);
                   console.log('create测试');                                      
             }
if (operation === 'delete_node') {
console.log(node.text);
console.log(position);
console.log('delete测试');
}
if (operation === 'rename_node') {
//console.log(parent.text);
console.log(position);
console.log(node.text);
console.log('rename测试');
}
console.log('测试区域');
return true;
},

通过在这里添加匿名函数,我们可以实现显示一些操作。我们将雁塔修改为123看是否触发了我们设置的匿名函数。

修改前:

修改后:

下面是打印了node节点的值,可以看到是一个对象。

通过上面的对比可以发现我们设置的匿名函数被成功的触发了,可以发现这里的参数都有一些特殊的作用。分析下这个函数里面的参数operation,node,parent,position,more。

  • operation:这个是看我们右键选择了什么功能。是删除,添加,移动,修改等。
  • node:表示当前对象的值,里面保存有这个节点里面的一些属性。
  • parent:表示父类节点对象。
  • position:表示当前节点的text值。比如我们上图的123就是在后台打印了position的原因。
  • more:这个现在打印不出来,也不清楚干什么用的。

我们现在已经知道了每个参数的区别,我们就可以利用operation来看到底选择了哪些操作,接着就可以在相应的区域中进行post请求,不管是删除还是添加都没有问题。

我们就测试一个删除吧。就拿我上面的来说就需要在选择删除的区域进行请求操作。

             if (operation === 'delete_node') {
var url='api/areas/delete?id='+node.id;
$http.get(url)
.then(function(response){
console.log(response.state);
                      console.log('删除成功');
});
console.log(node.text);
              console.log(position);
console.log('delete测试');
}

这样我们就可以和后台进行交互了。

JsTree实现简单的CRUD的更多相关文章

  1. 8天掌握EF的Code First开发系列之2 简单的CRUD操作

    本文出自8天掌握EF的Code First开发系列,经过自己的实践整理出来. 本篇目录 创建控制台项目 根据.Net中的类来创建数据库 简单的CRUD操作 数据库模式更改介绍 本章小结 本人的实验环境 ...

  2. spring集成mongodb封装的简单的CRUD

    1.什么是mongodb         MongoDB是一个基于分布式文件存储的数据库.由C++语言编写.旨在为WEB应用提供可扩展的高性能数据存储解决方案. mongoDB MongoDB是一个介 ...

  3. Mongodb系列- java客户端简单使用(CRUD)

    Mongodb提供了很多的客户端: shell,python, java, node.js...等等. 以 java 为例实现简单的增删改查 pom文件: <dependencies> & ...

  4. springboot + mybatis 的项目,实现简单的CRUD

    以前都是用Springboot+jdbcTemplate实现CRUD 但是趋势是用mybatis,今天稍微修改,创建springboot + mybatis 的项目,实现简单的CRUD  上图是项目的 ...

  5. 【SSH三大框架】Hibernate基础第五篇:利用Hibernate完毕简单的CRUD操作

    这里利用Hibernate操作数据库完毕简单的CRUD操作. 首先,我们须要先写一个javabean: package cn.itcast.domain; import java.util.Date; ...

  6. 简单的CRUD(二)

    一.重构简单的CRUD 1.JDBC工具类 1.因为在crud中都包含一些相同的代码所以可以提取出来,抽取代码重构为工具类. 2.将工具类设置为static静态类,方便调用,不需要new对象. pub ...

  7. 简单的CRUD(一)

    一.JDBC的概述--(来源于百度) JDBC(Java DataBase Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问, ...

  8. Springboot项目搭建(1)-创建,整合mysql/oracle,druid配置,简单的CRUD

    源码地址:https://github.com/VioletSY/article-base 1:创建一个基本项目:https://blog.csdn.net/mousede/article/detai ...

  9. ASP.NET Core MVC+Layui使用EF Core连接MySQL执行简单的CRUD操作

    前言: 本章主要通过一个完整的示例讲解ASP.NET Core MVC+EF Core对MySQL数据库进行简单的CRUD操作,希望能够为刚入门.NET Core的小伙伴们提供一个完整的参考实例.关于 ...

随机推荐

  1. Webpack教程

    打开链接:Webpack教程

  2. (翻译)《Hands-on Node.js》—— Why?

    事出有因 为何选择event loop? Event Loop是一种推进无阻塞I/O(网络.文件或跨进程通讯)的软件模式.传统的阻塞编程也是用一样的方式,通过function来调用I/O.但进程会在该 ...

  3. 剑指Offer面试题:28.连续子数组的最大和

    一.题目:连续子数组的最大和 题目:输入一个整型数组,数组里有正数也有负数.数组中一个或连续的多个整数组成一个子数组.求所有子数组的和的最大值.要求时间复杂度为O(n).例如输入的数组为{1,-2,3 ...

  4. .NET开发笔记(二十三) 谷歌地图下载

    关于如何将地球经纬度坐标系统转换成程序中常用到的平面2D坐标系统,网上的文章很多,参考http://www.cnblogs.com/beniao/archive/2010/04/18/1714544. ...

  5. [.net 面向对象程序设计进阶] (15) 缓存(Cache)(二) 利用缓存提升程序性能

    [.net 面向对象程序设计进阶] (15) 缓存(Cache)(二) 利用缓存提升程序性能 本节导读: 上节说了缓存是以空间来换取时间的技术,介绍了客户端缓存和两种常用服务器缓布,本节主要介绍一种. ...

  6. 关于大型网站技术演进的思考(二十一)--网站静态化处理—web前端优化—下【终篇】(13)

    本篇继续web前端优化的讨论,开始我先讲个我所知道的一个故事,有家大型的企业顺应时代发展的潮流开始投身于互联网行业了,它们为此专门设立了一个事业部,不过该企业把这个事业部里的人事成本,系统运维成本特别 ...

  7. MySQL HASH分区

    200 ? "200px" : this.width)!important;} --> 介绍 基于给定的分区个数,将数据分配到不同的分区,HASH分区只能针对整数进行HASH ...

  8. .Net组件程序设计之序列化

     .Net组件程序设计之序列化 自动序列化 本篇给大家讲解一下在.NET中的序列化,它的用处非常之多,特别是对于某种环境下保存某种状态是很好的方法,接下来就来看一下吧. Serializable属性 ...

  9. Docker:镜像操作和容器操作

    镜像操作 列出镜像: $ sudo docker images REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE hello-world latest 0a6b ...

  10. Objective-C三方库: ZXEasyCoding

    对FastCoding做了二次封装, 实现更加便捷的存储和读取数据, 分享给大家 ZXEasyCoding 说明: 对FastCording进行封装, 更便捷存储和读取对象数据 安装: 添加ZXEas ...