13

讨厌打开一个新问题来扩展上一个问题:

function ctest() {
    this.iteration = 0;
    this.func1 = function() {
        var result = func2.call(this, "haha");
        alert(this.iteration + ":" + result);
    }
    var func2 = function(sWord) {
        this.iteration++;
        sWord = sWord + "lol";
        if ( this.iteration < 5 ) {
            func2.call(this, sWord);
        } else {
            return sWord;
        }
    }
}

这将返回迭代 = 5 但结果未定义?这怎么可能?我明确返回 sWord。它应该已经返回“hahalollollollollol”并且只是为了仔细检查,如果我在返回 sWord 之前发出警报(sWord),它会正确显示它。

4

4 回答 4

29

您必须一直返回堆栈:

func2.call(this, sWord);

应该:

return func2.call(this, sWord);
于 2012-05-23T12:05:12.097 回答
5

您需要返回递归的结果,否则该方法隐式返回undefined。尝试以下操作:

function ctest() {
this.iteration = 0;
  this.func1 = function() {
    var result = func2.call(this, "haha");
    alert(this.iteration + ":" + result);
  }
  var func2 = function(sWord) {
    this.iteration++;
    sWord = sWord + "lol";
    if ( this.iteration < 5 ) {
        return func2.call(this, sWord);
    } else {
        return sWord;
    }
  }
}
于 2012-05-23T12:05:34.793 回答
1

您的外部函数没有return语句,因此它返回undefined.

于 2012-05-23T12:04:00.193 回答
1

把事情简单化 :)

您在 JSFiddle 中修改的代码

iteration = 0;
func1();

    function  func1() {
        var result = func2("haha");
        alert(iteration + ":" + result);
    }

    function func2 (sWord) {
        iteration++;

        sWord = sWord + "lol";
        if ( iteration < 5 ) {
            func2( sWord);
        } else {

            return sWord;
        }

    return sWord;
    }
于 2012-05-23T12:17:16.310 回答