Skip to content Skip to sidebar Skip to footer

Javascript Return Of Recursive Function

Hate to open a new question for an extension to the previous one: function ctest() { this.iteration = 0; this.func1 = function() { var result = func2.call(this, 'ha

Solution 1:

You have to return all the way up the stack:

func2.call(this, sWord);

should be:

return func2.call(this, sWord);

Solution 2:

You need to return the result of the recursion, or else the method implicitly returns undefined. Try the following:

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

Solution 3:

Solution 4:

keep it simple :)

your code modified in JSFiddle

iteration = 0;
func1();

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

    functionfunc2 (sWord) {
        iteration++;

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

            return sWord;
        }

    return sWord;
    }

Post a Comment for "Javascript Return Of Recursive Function"