JS——闭包中关于函数数组的问题

JavaScript中闭包是一大关键点,书上认为闭包是指有权访问另一个函数作用域中的变量的函数。创建闭包的常见方式就是在一个函数内部创建另一个函数。

由于在JavaScript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成"定义在一个函数内部的函数"。

所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。

我按照书上的例子,却久久不能实现。。。

错误的写法:

<!DOCTYPE html>
<html>
<body>

<script type="text/javascript">
function createFunctions() {
var result = new Array();

for(var i=0;i<10;i++) {
result[i] = function() {
return i;
};
}
return result;
}

var arr = createFunctions();
alert(arr);

</script>

</body>
</html>


错误原因:这里返回的result数组其实是函数数组。由于result[i] = function(){...};

所以这时候不能alert(arr);

修正的代码:

<!DOCTYPE html>
<html>
<body>

<script type="text/javascript">
function createFunctions() {
var result = new Array();

for(var i=0;i<10;i++) {
result[i] = function() {
return i;
};
}
return result;
}

var arr = createFunctions();
for(i=0;i<10;i++) {
alert(arr[i]());
}

</script>

</body>
</html>

附上另一段代码,比较清晰的证明了闭包和作用域的问题:

<!DOCTYPE html>
<html>
<body>

<script type="text/javascript">
function f1(){
    var n=999;
    nAdd=function(){n+=1}
    function f2(){
      alert(n);
    }
    return f2;
  }
  var result=f1();
  result(); // 999
  nAdd();
  result(); // 1000
</script>

</body>
</html>

nAdd是一个全局变量,等于一个匿名函数,这个匿名函数即闭包。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值