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の直前にalert(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 に答える