ES5 有两种声明变量的方法:var 和 function命令
ES6 有六种声明变量的方法:var 、 function 、let 、const 、import、class命令。
ES6 中新增了 let 和 const 来定义变量:
var:ES5 和 ES6中,定义全局变量(是variable的简写)。
let:定义
局部变量
,替代 var。const:定义
常量
(定义后,不可修改)。
var:全局变量
看下面的代码:
{
var a = 1;
}
console.log(a); //这里的 a,指的是 区块 里的 a
上方代码是可以输出结果的,输出结果为 1。因为 var 是全局声明的,所以,即使是在区块里声明,但仍然在全局起作用。
再来看下面这段代码:
var a = 1;
{
var a = 2;
}
console.log(a); //这里的 a,指的是 区块 里的 a
上方代码的输出结果为 2 ,因为 var 是全局声明的。
用 var 定义的全部变量,有时候会污染整个 js 的作用域。
要习惯用let声明,减少var声明去污染全局空间,在vue的使用中也要注意这点。
ES6 新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。
{
let a = 10;
var b = 1;
}
a // ReferenceError: a is not defined.
b // 1
const 声明的是一个只读的变量,一旦声明,不可更改,这就意味着一旦声明就必须初始化,不然会报错,const作用域和let作用域一样.
全局变量的属性
window.a = 1;
var a = 2 ;
console.log(a); // 2
console.log(window.a); // 2
window.b = 1;
let b = 2 ;
console.log(b); // 2
console.log(window.b); // 1
- 块级作用域
ES5只有全局作用域和函数作用域,会出现以下的问题
//内层变量覆盖了外层变量
var number = 5;
show();
function show(){
console.log(number); // undefined
var number = 10 ;
}
//i泄露成全局变量
var string = 'hello';
for(var i = 0 ;i<string.length ;i++){
console.log(string[i]); // h e l l o
}
console.log(i); // 5
ES6块级作用域写法(块级作用域可以无限嵌套,可以代替ES5的匿名函数IIFE)
{
let number = 5;
console.log(number); // 5
{
let number = "hello";
console.log(number); // hello
}
}
ES5严格模式下,函数不能在块级中声明,ES6明确规定可以在块级作用域中声明函数,但声明的函数有点类似let,在块级作用域之外不可引用,由于浏览器可以忽略以上规则,所以尽量避免在块级作用域中声明函数。
//ES5非严格模式
if(true){
function show(){ //不报错
};
}
//ES5严格模式
'use strict';
if(true){
function show(){ //直接报错
};
}
//ES6严格模式
'use strict';
if(true){
function show(){ //不报错
};
}