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作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

JS纯前端实现浏览器语音播报、朗读功能的完整代码

《JS纯前端实现浏览器语音播报、朗读功能的完整代码》在现代互联网的发展中,语音技术正逐渐成为改变用户体验的重要一环,下面:本文主要介绍JS纯前端实现浏览器语音播报、朗读功能的相关资料,文中通过代码... 目录一、朗读单条文本:① 语音自选参数,按钮控制语音:② 效果图:二、朗读多条文本:① 语音有默认值:②

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

C#实现高性能拍照与水印添加功能完整方案

《C#实现高性能拍照与水印添加功能完整方案》在工业检测、质量追溯等应用场景中,经常需要对产品进行拍照并添加相关信息水印,本文将详细介绍如何使用C#实现一个高性能的拍照和水印添加功能,包含完整的代码实现... 目录1. 概述2. 功能架构设计3. 核心代码实现python3.1 主拍照方法3.2 安全HBIT

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳