码迷,mamicode.com
首页 > 其他好文 > 详细

ECMAScript 6 学习笔记(二)

时间:2017-09-08 12:00:57      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:16px   ons   es6   length   let   log   blog   mil   const   

ECMAScript 6 let和const命令

let命令

基本用法

ES6新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。

{
  let a = 10;
  var b = 1;
}

a // ReferenceError: a is not defined.
b // 1

上面代码在代码块之中,分别用letvar声明了两个变量。然后在代码块之外调用这两个变量,结果let声明的变量报错,var声明的变量返回了正确的值。这表明,let声明的变量只在它所在的代码块有效。 

 

for循环的计数器,就很合适使用let命令。

for (let i = 0; i < arr.length; i++) {}

console.log(i);
//ReferenceError: i is not defined

上面代码的计数器i,只在for循环体内有效。

 

下面的代码如果使用var,最后输出的是10。

var a = [];
for (var i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 10

上面代码中,变量ivar声明的,在全局范围内都有效。所以每一次循环,新的i值都会覆盖旧值,导致最后输出的是最后一轮的i的值。

如果使用let,声明的变量仅在块级作用域内有效,最后输出的是6。

var a = [];
for (let i = 0; i < 10; i++) {
  a[i] = function () {
    console.log(i);
  };
}
a[6](); // 6

上面代码中,变量ilet声明的,当前的i只在本轮循环有效,所以每一次循环的i其实都是一个新的变量,所以最后输出的是6。

 

ECMAScript 6 学习笔记(二)

标签:16px   ons   es6   length   let   log   blog   mil   const   

原文地址:http://www.cnblogs.com/jinxiblog/p/7493344.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!