ES6笔记-- let和const
2017-09-14 00:00
169 查看
先说说let。let有块级作用域一说,即{}就是一个块级作用域。在{}内使用let声明的变量,{}外无法使用。
再就是和var的区别在于for循环中,在for循环中时候var声明的变量,i指向同一个,而是用let声明的变量都是独立的。
let命令不存在变量提升,存在暂时性死区,所以养成好习惯:变量一定要先声明后使用。
对于函数声明,环境导致的行为差异,避免在块级作用域内声明函数。如果确实需要,也应该写成函数表达式,而不是函数声明语句!!!
对于const的理解,需要注意其 不变 的含义:const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。(所以对于非引用数据类型地址保存了该数值,而对于引用数据类型地址是一个指针),因此const声明的对象中的key,value是可以改变的,如果真的想将对象冻结,应该使用Object.freeze方法。
最后,在ES6中声明变量的方式有6中: var、function、let、const、import、class
{let a = 5} console.log(a) // Uncaught ReferenceError: a is not defined
再就是和var的区别在于for循环中,在for循环中时候var声明的变量,i指向同一个,而是用let声明的变量都是独立的。
var a = []; for (var i = 0; i < 10; i++) { a[i] = function () { console.log(i); }; } a[6](); // 10 循环内被赋给数组 a 的函数内部的console.log(i),里面的 i 指向的就是全局的 i var a = []; for (let i = 0; i < 10; i++) { a[i] = function () { console.log(i); }; } a[6](); // 6 当前的 i 只在本轮循环有效,所以每一次循环的i其实都是一个新的变量
let命令不存在变量提升,存在暂时性死区,所以养成好习惯:变量一定要先声明后使用。
对于函数声明,环境导致的行为差异,避免在块级作用域内声明函数。如果确实需要,也应该写成函数表达式,而不是函数声明语句!!!
对于const的理解,需要注意其 不变 的含义:const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。(所以对于非引用数据类型地址保存了该数值,而对于引用数据类型地址是一个指针),因此const声明的对象中的key,value是可以改变的,如果真的想将对象冻结,应该使用Object.freeze方法。
最后,在ES6中声明变量的方式有6中: var、function、let、const、import、class
相关文章推荐
- 笔记:ES6新特性-变量声明关键字:let和const
- ES6基本语法学习笔记--let与const
- ES6笔记之一 let const 解构
- ES6 笔记: 2.let和const命令
- ES6-个人学习笔记一--let和const
- ES6笔记(2)-- let的块级作用域
- JavaScript ES6中const、let与var的对比详解
- es6学习-let和const命令
- es6 箭頭函數 let, const
- es6学习第一篇(let和const命令)
- ES6 let、var、const联系与区别
- [ES6语法1]let和const
- ES6 let & const
- ES6 之 let和const命令
- ES6小实验-let和const(2)
- ECMAScript6笔记:let和const命令
- 初学ES6(一) let和const
- ES6(01 基础 let和const命令)
- es6 箭頭函數 let, const
- ES6学习2章:let和const命令