ES6 新增加了两个重要的 JavaScript 关键字 :let  const

先说一下 const :它用于声明一个只读的常量,一旦声明,常量的值就不能改变。

const servicePath = "www.baidu.com";
servicePath = "www.sina.com";
console.log(servicePath);
//Uncaught TypeError: Assignment to constant variable.

由于const声明的是一个只读变量,不可被改变,所以声明变量是就必须赋值,否自也会报错。

const servicePath;
console.log(servicePath);
//Uncaught SyntaxError: Missing initializer in const declaration

要注意的是用const声明的常量如果是一个  Object  ,虽然Object.item不会被改变,但是可以用 Object.push(something)添加数组内容,如果不希望数组被改变,可使用 Object.freeze()将其冻结。

 const arr1 =['apple','banana'];
    arr1.push('orange');
console.log(arr1);
//["apple", "banana", "orange"]
const arr2 = Object.freeze(['apple','banana']);
arr2.push('orange');
console.log(arr2);
//Uncaught TypeError: Cannot add property 2, object is not extensible

let 用法与之前的 var 大致上相同,要注意的几点是:

1. 同一个作用域里, 不能重复定义变量(可以重新赋值) 。

  { }括起来的的区域是一个块级作用域,不同的块级作用域 let 两个相同名字的变量,实际上是两个完全独立没有联系的变量。

 1 function a(){
2   let a = "abc";
3   let b = "abc";
4   let c = 10;
5   console.log(a);// abc
6   function b(){
7     let a = 22;
8     console.log(a);//22
9   }
10   function c(){
11     let a = function(){return 1;}
12     console.log(a);//1
13   }
14   let b = 22;
15   console.log(b);//Identifier 'b' has already been declared
16   c = 15;
17   console.log(c);//15
18 }

2. 没有预解析,不存在变量提升。

 function fn(){
  alert(a); //TDZ开始 暂时性死区
let a = 5; //TDZ 结束
}
fn();
//a is not defined

3. for循环,for循环里面是父级作用域,{ }里面又一个作用域

 var arr1 =[];
for(var i=0; i<10; i++){
   arr1[i]=function(){
   console.log(i);
5   }
6 }
7 arr1[5](); // 9 var arr2 =[];
10 for(let i=0; i<10; i++){
11   arr2[i]=function(){
   console.log(i);
}
14 }
15 arr2[5]();//5

在熟悉 let 和 const 的用法之后 ,建议逐步放弃var的用法,改为使用 let 或者 const。

PS:在顶层作用域下 var 定义变量是属于window的,而 let 和 const  不属于。

ECMAScript(ES) 6 之 let 与 const的更多相关文章

  1. ECMAScript 6中的let和const关键词

    ECMAScript 6中多了两个定义变量的关键词,一个是let,另一个是const,后者顾名思义就是常量定义,前者的作用域范围是块级的. 一般写过js的童鞋都知道,同其他语言一样,JS中的变量作用域 ...

  2. ECMAScript 6 第一天 let和const命令

    ES6新增声明变量的方法let命令,const命令. (ES5只有两种声明变量的方法:var 命令和 function 命令.) let命令,用来声明变量. 与var声明变量不同于: 1.  let声 ...

  3. ECMAScript 6 新特性-set。const

    一.let命令是es6新增的特性,作用与var命令类似,声明变量,不同之处在于声明的变量的作用域为块级作用域.引入let后带来了很多新的特性. 1作用域,es5之前之后函数作用域和全局作用域,let的 ...

  4. ECMAScript 6 入门之let和const的用法

    1.let的用法 1. //查看js的引入路径是否正确 console.log("1:",1) 2. var a=1; let b=2; console.log("a:& ...

  5. ECMAScript 6中的var,let,const

    var的变量提升 console.log(a); //输出undefined ; 他的实际执行顺序是: var a: console.log(a); a= 这就是var的变量提升 const命令的用法 ...

  6. let和const关键词

    ECMAScript 6中的let和const关键词 2013-11-28 21:46 by BarretLee, 21 阅读, 0 评论, 收藏, 编辑 ECMAScript 6中多了两个定义变量的 ...

  7. ECMAScript 6入门

    预计在2014年底,ECMAScript 6将会正式发布,他的草案在13年3月份被冻结,后续提出新特性将会移至ECMASript 7中.目前还没有哪款浏览器实现了ES6的全部内容,兼容性最强的一款要数 ...

  8. ECMAScript 6 简介

    ECMAScript 6 是JavaScript的下一个标准,正处在快速开发之中,大部分已经完成了,预计将在2014年正式发布.Mozilla将在这个标准的基础上,推出JavaScript 2.0. ...

  9. JavaScript简易教程(转)

    原文:http://www.cnblogs.com/yanhaijing/p/3685304.html 这是我所知道的最完整最简洁的JavaScript基础教程. 这篇文章带你尽快走进JavaScri ...

随机推荐

  1. 2019.9.23JAVA动手动脑

    1请看以下代码,你发现了有什么特殊之处吗? // MethodOverload.java// Using overloaded methods public class MethodOverload ...

  2. Android学习笔记之Menu的ShowAsAction属性的设置

    (1)在res--menu目录下的main.xml文件 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 2 ...

  3. DVWA--XSS(stored)

    XSS 0X01 1.简介 跨站脚本(cross site script)为了避免与样式css混淆,所以简称为XSS. XSS是一种经常出现在web应用中的计算机安全漏洞,也是web中最主流的攻击方式 ...

  4. Vue 使用v-bind:style 绑定样式

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. Oracle诊断:drop table失败[转]

    转: From <http://blog.csdn.net/cyxlxp8411/article/details/7775113> 今天在drop一张表的时候报ORA-00054错误 SQ ...

  6. C#的keyValue

  7. win 10 hosts文件不生效

    win 10 hosts文件不生效       windows 10 hosts文件修改了,但是怎么都无法在浏览器中进行解析.一直都在等待,直到链接超时. 最后解决办法: 把hosts文件内容复制出来 ...

  8. MS入门学习笔记

    1.建立晶体:选择晶系,添加原子:2.导入系统晶体文件:3.建立分子molecule,画原子:4.计算简单分子molecule:注意事项: 1)做了一个H2O分子,接下来要做一个“立体壳子”,因为CA ...

  9. 2、node-webkit运行web应用,node-webkit把web应用打包成桌面应用

    下面我通过一个简单的demo来介绍怎么样把一个web应用打包成一个可执行文件(这里只介绍windows环境) 首先新建一个index.html文件,作为我们这个demo的入口页面,我们暂且就把这个页面 ...

  10. leetcode 53. Maximum Subarray 、152. Maximum Product Subarray

    53. Maximum Subarray 之前的值小于0就不加了.dp[i]表示以i结尾当前的最大和,所以需要用一个变量保存最大值. 动态规划的方法: class Solution { public: ...