码迷,mamicode.com
首页 > 其他好文 > 详细

let和const

时间:2019-08-27 19:34:58      阅读:61      评论:0      收藏:0      [点我收藏+]

标签:初始化   color   赋值   pre   lex   col   cal   改变   需要   

ES5中只有全局作用域和函数作用域,没有块级作用域。在ES6中多了一个块级作用域, {}在ES6中用来形成块级作用域,即代码块。

let命令声明的变量只在let代码块内有效,声明之后可以改变变量的值。 let不会发生变量提升的现象,需要在定义后使用,否则报错。

下例中,由于var命令的变量提升机制,var 命令实际只会执行一次,接下来的循环都是在改变var声明的变量i:

var a = [];
for(var i=0;i<10;i++){
    a[i] = function(){
        console.log(i);
     }
}
        
a[6]();  //10  

下例中,let命令不存在变量提升,所以每次循环都会执行一次,即每次循环都会声明一个新变量(但初始化的值不一样);for 的每次循环都是不同的块级作用域,let 声明的变量是块级作用域的,所以也不存在重复声明的问题;let声明变量的for循环里,每个a[i]函数实际上引用的都是一个新的变量。

既然let每一轮循环的变量i都是重新声明的,那它怎么知道上一轮循环的值,从而计算出本轮循环的值?由于let的变量作用域在for区块中,会为每次循环执行建立新的词法环境(LexicalEnvironment),拷贝所有的变量名称与值到下个循环执行。

 

var a = [];
for(let i=0;i<10;i++){
    a[i] = function(){
        console.log(i);
     }
}
        
a[6]();  //6 

 

const用来定义常量,使用时必须赋值,变量不能提升,只能在块作用域里访问,const命令只是保证变量名指向的地址不变,并不保证该地址的数据不变。

let和const

标签:初始化   color   赋值   pre   lex   col   cal   改变   需要   

原文地址:https://www.cnblogs.com/xjy20170907/p/11420066.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!