JS for循环 闭包

对于for循环的闭包问题的理解,认为需要理解函数中的变量的作用域链的概念 另外提及下变量提升的概念

如下例子:

var ar = [];
for(var i=1;i<10; i++){
  ar[i] = function(){
    console.log(i);
  }
}

ar[5]       // 打印为10;因为有闭包函数的问题

理解好闭包,应该理解好函数中变量的作用域概念。

首先,函数是有自己的执行环境(context)概念,函数的变量,就有变量作用域链。函数中,可以声明自己的局部变量,函数外是访问不到的。函数同样可以利用函数外声明的变量,但是此变量不属于函数。函数中变量的利用,存在一个在执行环境的变量作用域链查找的问题,若在函数内找不到声明,就到函数外找,如下图

JS for循环 闭包(注:此图为转用,非本人制作)
因此就能很好的解释为啥上述例子结果是10的问题,因为子function利用的i,在子function没有局部定义,于是按照变量作用域链的方式查找,但是for循环是继续执行的,所以,当找到变量的时候,for循环已经执行完,于是结果为10。

通过函数的形式,产生了闭包。可通过传递参数,函数立即执行的方式,解决闭包。另外,还可通过let定义变量的方式 for(let i=0; i<10; i++){}。

对于变量的声明提升的概念就是,只要在

    function(){
      alert(i);
      var i=9 ;

    }
  实际是这样的
    function(){
        var i;
        alert(i);
        i = 9;
    };

上一篇:TMS320VC5509的MCBSP配置成SPI模式通信


下一篇:URL Routing