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<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(){    //不报错
    };
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 《ECMAScript入门》是一本开源的JavaScript语言教程,全面介绍ECMAScript6新引入的...
    weiqinl阅读 3,486评论 0 1
  • let和const let命令 let用法类似var,但是所声明的变凉,只在let命令所在的代码块内有效 for循...
    李诺哦阅读 2,795评论 0 1
  • JavaScript共包含三个部分:ECMAScript、DOM和BOM,而我们今天开始所要讲的ES6的全称就是E...
    前端王睿阅读 4,336评论 5 18
  • 各位亲爱的同事:欢迎您来到丽江,当你出走机场那一刻,就睁大眼睛,大口呼吸吧,空气带着玉龙雪山纯净,在阳光的照射下,...
    木雨瑾阅读 2,895评论 0 2
  • 文——若风 傍晚了 你这个时候在天边认真的看着我吧 哭的鼻涕那么长 也不擦 那件红风衣 还很漂亮 我猜 你大概是跟...
    G沐风阅读 2,394评论 0 1