JavaScript中使用var定义变量可能存在以下问题:
1.var 定义的变量没有块作用域。
2.var 定义的全局变量会自动添加全局window对象的属性。
3.var定义的变量会提前装载。
let 关键字正是为了解决上述问题而出现的,
1.
上面程序在for循环中使用let来定义循环计数器,这样i将只会在for循环中有效,因此程序在循环体外访问i就会报错,如果将let改为var,那么在循环体中定义的i就会扩散到循环体之外。
2.
上面代码 使用let定义了个name,这个name不在任何函数中,所以是个全局变量。但与var定义的全局变量不同的是,使用let定义的全局变量不会变成window对象的属性,因此上面代码输出window.name时看不到任何输出。
3.
使用var定义的变量会提前装载,而使用let定义的变量要等到程序流执行到定义变量的代码是才会装载。
上面程序先定义了一个全局的name变量,接下来在func()函数中使用let定义了一个局部变量name,此时局部变量name会完全覆盖全部变量name,由于使用let定义的局部变量不会提前装载,因此访问let上面那个name变量会导致错误。如果将let改为var定义,则会先输出 undefined,再输出局部变量name的值。
综上所述,let关键字的出现正是为了弥补var的缺陷,因此对于支持let的浏览器,读者应该考虑使用let代替var.
JavaScript新增的let变量作用
最新推荐文章于 2020-10-30 18:10:37 发布