的递归下的循环不能使用forEach  可以使用for代替

错误写法

// 获取完整名字
        var getFullName = function(code, resultName) {
          if (code === '0') {
            return resultName;
          } else {
            popup.fullData.forEach(function (val) {
              if (code === val.code) {
                var text = val.text + resultName;
                return getFullName(val.parentcode, text);                
              }
            });
            /*for (var i = 0, length = popup.fullData.length; i < length; i++) {
              if (code === popup.fullData[i].code) {
                var text = popup.fullData[i].text + resultName;
                return getFullName(popup.fullData[i].parentcode, text);
                break;
              }
            }*/
          }
        };

 

正确写法

// 获取完整名字
        var getFullName = function(code, resultName) {
          if (code === '0') {
            return resultName;
          } else {
            for (var i = 0, length = popup.fullData.length; i < length; i++) {
              if (code === popup.fullData[i].code) {
                var text = popup.fullData[i].text + resultName;
                return getFullName(popup.fullData[i].parentcode, text);
                break;
              }
            }
          }
        };

可能原因是foreach中的return是终端循环作用  而不是返回总用  具体原因我也不知道  求大神指教

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-06-05
  • 2021-05-19
猜你喜欢
  • 2022-12-23
  • 2022-02-07
  • 2021-12-06
  • 2021-04-18
  • 2021-06-05
相关资源
相似解决方案