我们都知道在最新的 ES6 中,新添加了两个用于变量声明的关键字 let 和 const,那么这两个和我们以前经常使用的 var 有什么区别呢?今天我们就来看一下吧。
变量声明和初始化
在比较它们的区别之前,我们先来看一下变量声明和初始化。变量声明:
var str
变量声明会引入了一个新的标识符 declaration,在 JavaScript 中,新创建的变量的默认值都是 undefined。我们再来看一下变量赋值:
var str
console.log(str) // undefined
str='hello'
str 变量被我们赋予了一个值。
作用域
JavaScript 的世界共有两种作用域:全局作用域和方法作用域。使用 var 声明的变量的作用域是方法作用域,如下 date 变量在方法外面不可访问的:
function getDate(){
var date = new Date() 在getDate方法外不可访问
return date;
}
看起来蛮正常的。var 变量关键字的真正问题在于其在方法内部的定义变量开始的任何地方都可以访问到这个变量。
如下所示,i、discountedPrice、finalPrice 这三个变量是定义在一个 for 循环体中的 (即位于块作用域中),按照正常思维来讲,在循环结束后,这三个变量是不可访问的,
但是现在在这个整个大的方法中,依然是可以访问的: