讨厌为前一个扩展程序打开一个新问题:
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)它正确地显示它。
答案 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;
}