当前位置: 首页 > news >正文

gulimall项目笔记:P54三级分类拖拽功能实现

gulimall项目笔记:P54三级分类拖拽功能实现

技术方案

采用ElementUI的Tree树形控件实现分类拖拽功能

Tree控件界面示例

功能规则

  • 层级限制:分类结构最多支持3级
  • 拖拽验证:通过ElementUI的allow-drop事件实现

核心参数

allow-drop事件包含三个关键参数:

  1. draggingNode - 拖拽中的节点
  2. dropNode - 目标放置节点
  3. type - 拖拽类型(‘prev’、‘inner’、‘next’)

参数说明图示

参数draggingNodedropNode包含两个重要属性:

  • childNodes - 子节点集合
  • level - 节点层级

节点属性说明

实现逻辑

1.计算子树深度(countNodeLevel方法)
首先通过计算当前拖拽节点draggingNode的最大子树的level

countNodeLevel(node) {if(node.childNodes != null && node.childNodes.length > 0){for(let i = 0; i< node.childNodes.length; i ++){if(node.childNodes[i].level > this.maxLevel){this.maxLevel = node.childNodes[i].level;}this.countNodeLevel(node.childNodes[i]);}	}
}

然后在计算出draggingNode的最大深度deep
deep = this.maxLevel – draggingNode.level + 1
基于这些参数,三级目录结构可归纳为三种情况:

在这里插入图片描述

2.允许拖拽判断(allowDrop方法):
然后根据拖拽放置类型type(inner表示插入目标节点内,prev或next表示放置在目标节点前后)来判断是否允许拖拽。如果是inner类型,判断deep + dropNode.level <= 3;如果是before或after类型,判断deep + dropNode.parent.level <= 3。

if (type == ‘inner’) {return deep + dropNode.level <= 3;
}else{return deep + dropNode.parent.level <= 3;
}

扩展

如果层级限制的分类结构最多支持n级,我们只需要把<= 3改成<= n即可。

http://www.dtcms.com/a/332854.html

相关文章:

  • 《Attention-driven GUI Grounding》论文精读笔记
  • CSS Houdini 与 React 19 调度器:打造极致流畅的网页体验
  • 【Redis】Redis典型应用——分布式锁
  • 【Redis】分布式系统的演化过程
  • KNN 算法
  • 高频量化详解,速度和程序化的满足!
  • 卷积神经网络(CNN)学习笔记
  • 基本电子元件:贴片电阻器的种类
  • 序列晋升6:ElasticSearch深度解析,万字拆解
  • Spring事物
  • 如何理解AP中SM中宿主进程?
  • 艾伦·图灵:计算理论与人工智能的奠基人
  • 云原生俱乐部-k8s知识点归纳(4)
  • 数据结构初阶:排序算法(一)插入排序、选择排序
  • uniapp纯前端绘制商品分享图
  • 18- 网络编程
  • 【学习笔记】Java并发编程的艺术——第10章 Executor框架
  • 从PDF到洞察力:基于飞算JavaAI的智能文档分析引擎实战
  • canoe面板中的进度条的使用
  • 分享一个基于Hadoop的二手房销售签约数据分析与可视化系统,基于Python可视化的二手房销售数据分析平台
  • AI工作流入门指南:从概念到实践
  • Redis 缓存和 Redis 分布式锁
  • SpringCloud -- Nacos详细介绍
  • Vue3从入门到精通: 4.5 数据持久化与同步策略深度解析
  • 电工的基础知识以及仪器的使用
  • linux下用c++11写一个UDP回显程序
  • 什么是敏感内容识别技术?
  • 平替 Claude Code,API接入 GPT-5,Codex CLI 国内直接使用教程
  • linux-数据链路层
  • ChatGPT-5(GPT-5)全面解析:一场从通用智能迈向专属智能的进化风暴,正在重塑人类与机器的协作边界