js中var和let的区别
var:声明全局变量
var的问题:
(1). 会被声明提前——打乱程序正常的执行顺序
(2). 没有块级作用域——代码块内的变量,很有可能影响块外的代码!
块级作用域: if,else,for,while,do while,switch等这些程序结构的{},在js中都不是作用域!这些{}防不住内部的var变量被声明提前到{}外部。即使在{}内声明的变量,出了{}依然可以使用!
let:专门代替var用于声明变量的新关键词
let的好处:
(1). 不会被声明提前——保证程序顺序执行
(2). 让代码块也变成了作用域!——保证块内的变量,无法超出块的范围影响外部!
let原理: let底层会悄悄的做两件事,来避免let的变量和外部变量同名!
(1). let会被自动翻译为匿名函数自调,有自己的作用域
(2). let的变量会被悄悄改名,避免重名——双保险!
let特点:
(1). 在全局let的变量,竟然在window里找不到!
(2). 在相同作用域内,不允许用let同时声明两个同名的变量
(3). 禁止提前使用let声明的变量