在js中变量声明是var,在最新的ES6中添加了两个变量声明的方式:let、const,以下是它们的不同之处。
var—变量声明会提升,没有块级作用域
在非严格模式下,没有用var声明的变量会被默认为全局变量,但是在严格模式下会报错。使用var定义全局变量时,不能用delete删除,而不使用var定义时可以删除。
1.变量声明提升:
console.log(a);//a is not defined
console.log(b);//undefined
var b = 0; //变量声明提升
2.没有块级作用域:
声明在for循环中的变量,跳出循环仍然可以使用
var arr=[1,2,3];
for(var i=0;i<arr.length;i++){
...
}
console.log(i);//在循环外可以使用
let —存在块级作用域,不存在变量声明提升
let在相同作用域下面不能重复声明变量,而var重复声明后,后者会覆盖前者。
let c = 3;
console.log('函数外let定义c:' + c); //输出c=3
function change() {
let c = 6;
console.log('函数内let定义c:' + c); //输出c=6
}
change();
console.log('函数调用后let定义c不受函数内部定义影响:' + c); //输出c=3
1.块级作用域
let arr=[1,2,3];
for(let i=0;i<arr.length;i++){
...
}
console.log(i);//在循环外不可以使用 i is not defined
const—const 和 let 的作用域是一致的,不同的是 const 变量一旦被赋值,就不能再改变了
const用来声明常量,必须进行初始化,不能重复声明。一旦声明后它的值就不能更改,不能重复赋值。
const b;//未初始化
console.log(b);//Missing initializer in const declaration
const c=3;
const c=4;//重复声明
console.log(c);//Identifier 'c' has already been declared