ES6中let 和 const 的新特性
2018-09-03 16:51
736 查看
在javascript中,我们都知道使用var来声明变量。javascript是函数级作用域,函数内可以访问函数外的变量,函数外不能访问函数内的变量。本文给大家介绍ES6中let 和 const 的特性,具体内容如下所示:
let的特性:
1.不存在变量提升现象:即声明前使用,报ReferenceError。适用于for循环计数器。
2.暂时性死区:即在块级作用域内使用let声明变量,该变量只能在该作用域内使用。
3.不允许重复声明:let声明过的变量不能再次声明,否则报错。
const的特性:
1.不存在变量提升现象。
2.暂时性死区。
3.不可重复声明。
4.声明的是只读常量,声明时必须初始化。
5.本质保存的是内存地址,简单类型数据的值就保存在这个地址中,复合类型数据在这个地址中保存的是一个指针,这个指针指向的对象可以改变,单指针不可改变。
cost foo = {}; // 可以改变foo的属性 foo.prop = 123; foo.prop //123 // 不可以使foo指向别的对象 foo = {}; //TypeError: "foo" is read-only
冻结对象:
// 彻底冻结 var constantize = (obj) => { Object.freeze(obj); Object.keys(obj).forEach( (key, i) => { if( typeof obj[key] === 'object' ){ constantize( obj[key] ); } }); }
总结
以上所述是小编给大家介绍的ES6中let 和 const 的特性 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- ES6新特性:let和const的使用
- 笔记:ES6新特性-变量声明关键字:let和const
- ES6新特性 let、const、变量对象的解构赋值
- ES6新特性:块级作用域let和const
- ES6新特性一: let和const命令详解
- [ES6语法1]let和const
- 【es6】 let & const
- ES6笔记之一 let const 解构
- 1、 ES6语法let、const
- es6 箭頭函數 let, const
- 简说ES6中的变量定义:let、const
- ES6 var和let和const 的区别
- es6学习-let和const命令
- ECMAScript6(ES6)标准之let、const关键字与块级作用域
- es6新语法:let、const
- var与ES6中const、let声明的变量的区别
- ES6(01 基础 let和const命令)
- 1、ES6 === let && const
- 学阮大大ES6摘录let&const
- ES6(let \ const)