JavaScript ES6语法中let,const ,var 的区别
作者:小高今天早睡了吗?
这篇文章主要为大家介绍了JavaScript中let,const ,var 的区别,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
一、变量声明的方式let / const
let / const 共同点1.都是块级作用域
2.在同一个作用域下,变量名不允许重复
3.他们声明的全局变量并没有挂在 window对象上
4.都没有预编译
let / const 不同点1.let 声明的变量值可以改变
2.const 声明的变量值不能改变,必须声明后立即赋值 (如:const a = 3.14;)
3.const 存引用数据类型时,内容可以发生改变(地址不能改变)
优先考虑使用const , 如果变量会发生改变,就使用let , 最后使用var
for循环中 var 和 let 的区别
var: 变量i是var命令声明的,在全局范围内都有效,所以全局只有一个变量i。每一次循环,变量i的值都会发生改变 ,而循环内被赋给计时器内部的函数console.log(i) 里面的i指向的就是全局的i。计时器是异步的,for循环结束后才执行。
for(var i = 1 ; i < 10 ; i++){
setTimeout(function () {
console.log(i); // 输出为 9 个 10
})
}
let:变量i是let声明的,当前的i只在本轮循环有效,所以每一次循环的i其实都是一个新的变量,所以最后输出的是 1 2 3 4 5 6 7 8 9 10 。因为 JavaScript 引擎内部会记住上一轮循环的值,初始化本轮的变量 i 时,就在上一轮循环的基础上进行计算。
for(let i = 0 ; i < 10 ; i++){
setTimeout(function () {
console.log(i); // 0 1 2 3 4 5 6 7 8 9
})
}
总结
本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!
您可能感兴趣的文章:
- javascript中的var、let、const最佳实践
- js中var,let,const的区别及相关面试题讲解
- JavaScript中var、let和const的用法及区别详解
- javascript中定义变量const和var有什么区别详解
- js中var、let、const之间的区别
- Js中var,let,const的区别你知道吗
- JavaScript变量中var,let和const的区别
- 浅谈JS中var,let和const的区别
- javascript 变量声明 var,let,const 的区别
- 面试官常问之说说js中var、let、const的区别
- javascript的var与let,const之间的区别详解
- JavaScript中const和var的区别小结
