关于函数闭包、函数作为参数传递疑问

1.描述:

我想得到一个函数数组 result ,首先func函数向数组result里添加匿名函数(每个匿名函数都保存了各自的num)

但是我将return 后面的匿名函数我用参数传进来,相当于只是做了替换而已,为什么结果却不同呢。

function func(){
  var result =[] ;
  for(var i=0;i<3;i++){
    result.push(
      function (num){
        return function (){
          return num
        }      
      }(i)
    )
  }
 return result
}

console.log(func()[1]())  //这样我就能得到各自函数里的num

下面我将 return 后面匿名函数作为参数传进去就获取不到。

function func(fn){
  var result =[] ;
  for(var i=0;i<3;i++){
    result.push(
      function (num){
        return fn;     
      }(i)
    )
  }
 return result
}

function fn(){
  return num
}
console.log(func(fn)[1]()) //报错提示num未定义
  
阅读 5.1k
4 个回答

因为第二段代码中的fn是定义在全局环境中的。
你可以看看这里和下边的代码,希望对你有帮助

function func(fn){
  var result =[] ;
  for(var i=0;i<3;i++){
    result.push(
      function (num){
        return fn;     
      }(i)
    );
  }
 return result;
}

function fn(){
  return num;
}
var num = 1;
console.log(func(fn)[1]()); //1

这就是一个很简单的作用域的问题,你的循环中定义的函数的形参只在这个函数中起作用。

函数是不应该在循环或者判断条件下定义的,会发生很多意想不到的问题。把你的函数拿出来定义,你会发现逻辑也清楚了许多。

num作用域问题,javascript存在函数作用域,num在第一个函数内部,而第二个函数在第一个函数外部,则第二个函数无法获取num.

改成这样就好了:

function func(fn){
  var result =[] ;
  for(var i=0;i<3;i++){
    result.push(
      function (num){
        return () => fn(num);     
      }(i)
    )
  }
 return result
}

function fn(num){
  return num
}
console.log(func(fn)[1]())
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题