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

相关文章

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.