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

【谷粒商城踩坑记】第五坑 拖拽组件三级菜单拖不了问题

第五坑 拖拽组件三级菜单拖不了问题

直接进入或刷新页面后,拖动第三级菜单项,无法修改排序位置,我尝试了直接用源码包中提供的老师的代码也不行,本身就有这个小 Bug ,或者说是其它什么地方有问题。

原始内容是这样的。

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]);
    }

},

其实原因就是第三级是没有 childNodes 的,maxLevel就会一直是0,到外面的计算代码中deep就一直计算的会是4。

allowDrop(draggingNode, dropNode, type) {
  //1、被拖动的当前节点以及所在的父节点总层数不能大于3

//1)、被拖动的当前节点总层数
console.log("allowDrop:", draggingNode, dropNode, type);
//
this.countNodeLevel(draggingNode);
//当前正在拖动的节点+父节点所在的深度不大于3即可
let deep = Math.abs(this.maxLevel - draggingNode.level) + 1;
console.log("深度:", deep);

//   this.maxLevel
if (type == "inner") {
    // console.log(
    //   `this.maxLevel:${this.maxLevel};draggingNode.data.catLevel:${draggingNode.data.catLevel};dropNode.level:${dropNode.level}`
    // );
    return deep + dropNode.level <= 3;
  } else {
    return deep + dropNode.parent.level <= 3;
  }
},

解决方案就是增加一个 else ,把当前节点的值赋给 maxLevel 就好了。

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]);
    }
  }else{
    this.maxLevel = node.level // 这一行
  }

},
http://www.dtcms.com/a/92200.html

相关文章:

  • 在Cesium中使用ThreeJs材质(不是场景融合哦)
  • 运维网络排查工具介绍与使用
  • 《Android低内存设备性能优化实战:深度解析Dalvik虚拟机参数调优》
  • 1963. 使字符串平衡的最小交换次数
  • Elasticsearch:使用 AI SDK 和 Elastic 构建 AI 代理
  • 瑞数信息《BOTS自动化威胁报告》正式发布
  • Struct2中自定义的Filter失效问题
  • .gitattributes与git lfs
  • CSS SEO、网页布局、媒体查询
  • 游戏交易系统设计与实现(代码+数据库+LW)
  • 系统分析师常考题目《论面向对象分析方法及其应用》
  • 相生、相克、乘侮、复杂病机及对应的脏腑功能联系
  • react 15-16-17-18各版本的核心区别、底层原理及演进逻辑的深度解析
  • 知识表示方法之一一阶谓词逻辑表示法(附详细示例)
  • 深入理解 JavaScript 的 `async/await`
  • 华为HCIE鸿蒙应用开发认证靠谱吗?
  • [linux] linux基本指令 + shell + 文件权限
  • 【更新中】【React】基础版React + Redux实现教程(Vite + React + Redux + TypeScript)
  • Oracle 数据库通过exp/imp工具迁移指定数据表
  • 文件操作 说明
  • python deepseek AI
  • ShapeCrawler:.NET开发者的PPTX操控魔法
  • STM32中不同FLASH的芯片启动文件选择规则
  • vue 封装 Axios菜鸟教程
  • STM32C011 进入停止模式和待机模式
  • 昇腾MindIE 限制非首token时延(TPOT)的极限吞吐
  • Windows命令提示符(CMD) 的常用命令分类整理
  • Google Benchmark性能测试
  • 质检LIMS系统在粮油加工企业的应用 粮油质检LIMS系统应用的痛点
  • AP CSA FRQ Q2 Past Paper 五年真题汇总 2023-2019