js函数中关于fn()和return fn()的一个问题
Author:zhoulujun Date:
在js中,经常会遇到在函数里调用其它函数的情况,这时候会有 fn() 这种调用方式,还有一种是 return fn() 这种调用方式,一些初学者经常会一脸萌逼地被这两种方式给绕晕了。这里用一个优雅的面试题来分析一下两种方式的不同之处。
var i = 0;
function fn(){
i++;
if(i < 10){
fn();
}else{
return i;
}
}
var result = fn();
console.log(result);
想不通为什么这里fn()不加return ,i自加到10,不走else,return的是undefined而不是10,我知道加了递归调用的时候加了return fn()就可以返回10,但是不能理解
var i = 0;
function fn(){
i++;
if(i < 10){
//不管什么代码,递归还是其他的,我不关心,它造个原子弹也行
fn()
//没有返回值吧?所以返回undefined
}else{
//后面的递归你不去想,第一次的fn并不会进入这个分支
return i;
}
}
var result = fn();
console.log(result);
不要被递归绕晕了,你不要管什么递归,它就是一个函数,在第一个fn进入的i<10分支里,没有返回值,那么这个函数就返回默认的undefined
我们这里减少一下递归层数,手把手的一层层展开
var i = 0;
function fn(){
i++; // 1
if(i < 2){
//fn()代码直接写进去
function() {
i++ // 2
if(i < 2) {
... //不会进入
}else {
return i
// 貌似这里有返回值, 但是这里是这个函数的返回值,
//不是上面fn的返回值,而且你并没有使用这个返回值
}
}()
}else{
return i;
}
}
最外层return没执行
可以这样理解
functon fn(){
i++
if(i < 2){
//没 return
(function fn(){
i++;
if(i<2){
}else{
rerurn i//return i
}
})
}else{
return i;//没执行
}
}
转载本站文章《js函数中关于fn()和return fn()的一个问题》,
请注明出处:https://www.zhoulujun.cn/html/webfront/ECMAScript/js/2009_0108_8077.html