let 和 const

参考ES6的介绍和常用语法

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

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(){    //不报错
    };
}

你可能感兴趣的:(let 和 const)