日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

【谷粒商城踩坑記】第五坑 拖拽組件三級菜單拖不了問題

 硬核項目經(jīng)理 2025-03-24 發(fā)布于湖南

第五坑 拖拽組件三級菜單拖不了問題

直接進入或刷新頁面后,拖動第三級菜單項,無法修改排序位置,我嘗試了直接用源碼包中提供的老師的代碼也不行,本身就有這個小 Bug ,或者說是其它什么地方有問題。

原始內(nèi)容是這樣的。


countNodeLevel(node){
// 找到所有子節(jié)點,求出最大深度
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、被拖動的當(dāng)前節(jié)點以及所在的父節(jié)點總層數(shù)不能大于3

//1)、被拖動的當(dāng)前節(jié)點總層數(shù)
console.log("allowDrop:", draggingNode, dropNode, type);
//
this.countNodeLevel(draggingNode);
//當(dāng)前正在拖動的節(jié)點+父節(jié)點所在的深度不大于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 ,把當(dāng)前節(jié)點的值賦給 maxLevel 就好了。


countNodeLevel(node){
// 找到所有子節(jié)點,求出最大深度
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 // 這一行
  }

},

    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多