小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

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

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

第五坑 拖拽組件三級(jí)菜單拖不了問題

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

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


countNodeLevel(node){
// 找到所有子節(jié)點(diǎn),求出最大深度
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]);
    }

},

其實(shí)原因就是第三級(jí)是沒有 childNodes 的,maxLevel就會(huì)一直是0,到外面的計(jì)算代碼中deep就一直計(jì)算的會(huì)是4。

allowDrop(draggingNode, dropNode, type) {
  //1、被拖動(dòng)的當(dāng)前節(jié)點(diǎn)以及所在的父節(jié)點(diǎn)總層數(shù)不能大于3

//1)、被拖動(dòng)的當(dāng)前節(jié)點(diǎn)總層數(shù)
console.log("allowDrop:", draggingNode, dropNode, type);
//
this.countNodeLevel(draggingNode);
//當(dāng)前正在拖動(dòng)的節(jié)點(diǎn)+父節(jié)點(diǎn)所在的深度不大于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;
  }
},

解決方案就是增加一個(gè) else ,把當(dāng)前節(jié)點(diǎn)的值賦給 maxLevel 就好了。


countNodeLevel(node){
// 找到所有子節(jié)點(diǎn),求出最大深度
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)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多