zTree做拖拽移动功能,并保存数据到数据库

2024-03-16 18:44

本文主要是介绍zTree做拖拽移动功能,并保存数据到数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

思路:zTree的拖拽移动功能是组件自带的,通过setting配置即可,保存到数据库则需要拿到移动节点id和目标父级id,后端去处理,把移动节点的数据挂到目标父级的下面。
这里只介绍前端处理

html:

<div class="container-div ui-layout-center" style="background:#fff"><div id="tree" class="ztree"></div><div style="position:absolute;left:400px;top:30px;"><div>移动节点:<span id="ydjd"></span></div><div>移动节点id:<span id="ydjd2"></span></div><br/><div>目标父级:<span id="mbfj"></span></div><div>目标父级id:<span id="mbfj2"></span></div></div></div>

script:

//先引入指定目录下的这三个js
<script th:src="@{/ajax/libs/jquery-ztree/3.5/js/jquery.ztree.core-3.5.js}"></script>
<script th:src="@{/ajax/libs/jquery-ztree/3.5/js/jquery.ztree.excheck-3.5.js}"></script>
<script th:src="@{/ajax/libs/jquery-ztree/3.5/js/jquery.ztree.exedit-3.5.js}"></script>var setting = {edit: {enable: true,showRemoveBtn: true,showRenameBtn: true,drag: {isCopy: false,isMove: true,prev: true,next: true,inner: true}},data: {key:{name:"name"},simpleData: {enable: true,idKey:"id",pIdKey:"pId",rootPid: "0"}},callback: {beforeDrag: beforeDrag,beforeDrop: beforeDrop,onDrop: onDrop,beforeRemove: beforeRemove,beforeRename: beforeRename,onRemove: onRemove,onRename: onRename}};var zNodes =[] ,//获取树数据接口$.ajax({url: ctx + "system/dept/currentTreeData",type: "get",async: false,success: function (res) {zNodes = res;zNodes[0].open=truet = $.fn.zTree.init($("#tree"), setting, zNodes)}})//在拖拽之前  可以用来做是否可拖拽限制function beforeDrag(treeId, treeNodes) {console.log('beforeDrag',treeNodes[0].title,treeId, treeNodes)$('#ydjd').html(treeNodes[0].title)$('#ydjd2').html(treeNodes[0].id)// if(treeNodes[0].isleaf == true){ //叶子节点// 	return false// }else{// 	return true// }}//用于捕获节点拖拽操作结束之前的事件回调函数,并且根据返回值确定是否允许此拖拽操作//默认值 nullfunction beforeDrop(treeId, treeNodes, targetNode, moveType) {}//用于捕获节点拖拽操作结束的事件回调函数  默认值: nullfunction onDrop(event, treeId, treeNodes, targetNode,moveType) {console.log(targetNode.title,event, treeId, treeNodes, targetNode,moveType)$('#mbfj').html(targetNode.title)$('#mbfj2').html(targetNode.id)}//删除节点之前执行的函数function beforeRemove(treeId, treeNode) {//删除节点执行的函数function onRemove(e, treeId, treeNode) {}//重命名之前执行的函数function beforeRename(treeId, treeNode, newName, isCancel) {}//重命名是执行的函数function onRename(e, treeId, treeNode, isCancel) {}

这篇关于zTree做拖拽移动功能,并保存数据到数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/816368

相关文章

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

MySQL数据库中ENUM的用法是什么详解

《MySQL数据库中ENUM的用法是什么详解》ENUM是一个字符串对象,用于指定一组预定义的值,并可在创建表时使用,下面:本文主要介绍MySQL数据库中ENUM的用法是什么的相关资料,文中通过代码... 目录mysql 中 ENUM 的用法一、ENUM 的定义与语法二、ENUM 的特点三、ENUM 的用法1

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

嵌入式数据库SQLite 3配置使用讲解

《嵌入式数据库SQLite3配置使用讲解》本文强调嵌入式项目中SQLite3数据库的重要性,因其零配置、轻量级、跨平台及事务处理特性,可保障数据溯源与责任明确,详细讲解安装配置、基础语法及SQLit... 目录0、惨痛教训1、SQLite3环境配置(1)、下载安装SQLite库(2)、解压下载的文件(3)、

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体