javascript返回递归函数

时间:2012-05-23 12:01:29

标签: javascript recursion return

讨厌为前一个扩展程序打开一个新问题:

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

这会返回iteration = 5,但结果是UNDEFINED?怎么可能?我明确地返回了sWord。它应该返回“hahalollollollollol”并且仅用于双重检查,如果我在返回sWord之前警告(sWord)它正确地显示它。

5 个答案:

答案 0 :(得分:22)

你必须一直回到堆栈:

func2.call(this, sWord);

应该是:

return func2.call(this, sWord);

答案 1 :(得分: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;
    }
  }
}

答案 2 :(得分:2)

 func2.call(this, sWord);

应该是

return func2.call(this, sWord);

答案 3 :(得分:0)

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

答案 4 :(得分:0)

保持简单:)

your code modified in 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;
    }