关于var函数作用域,闭包与let的区别应用,(前端网备份)

Posted lsc-boke

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于var函数作用域,闭包与let的区别应用,(前端网备份)相关的知识,希望对你有一定的参考价值。

var a = [];
for (var i = 0; i < 10; i++)
a[i] = (function(j)
return function() console.log(j); ;
)(i);

a[7]();

var b = [];
for (let i = 0; i < 10; i++) 
  b[i] =  function()
        console.log(i); 
    ;

b[7](); 
var pubvar = 1;
这两个结果是一样的

关于闭包的var
function createFunctions()
var result = new Array();
for (var i=0; i < 10; i++)
result[i] = function()
return i;
;

return result;

ClosureExample01.htm
这个函数会返回一个函数数组。表面上看,似乎每个函数都应该返自己的索引值,即位置0 的函数
返回0,位置1 的函数返回1,以此类推。但实际上,每个函数都返回10。因为每个函数的作用域链中
都保存着createFunctions() 函数的活动对象, 所以它们引用的都是同一个变量i 。当
createFunctions()函数返回后,变量i 的值是10,此时每个函数都引用着保存变量i 的同一个变量
对象,所以在每个函数内部i 的值都是10。但是,我们可以通过创建另一个匿名函数强制让闭包的行为
符合预期,如下所示。

以上是关于关于var函数作用域,闭包与let的区别应用,(前端网备份)的主要内容,如果未能解决你的问题,请参考以下文章

var与let区别-详解块级作用域与局部作用域

var与let区别-详解块级作用域与局部作用域

JavaScript闭包的用法和场景

Vue语法

聊聊var与let 在window下面的区别(除开作用域)

JavaScript中的 let 和 var