Ecmascript 6新特性
- 声明变量由var变成let。
let实际上为JavaScript新增了块级作用域。let与var相比具有的特性有
1、不允许重复声明一个变量
var a=5;
var a=7;
let b=6;
let b=8;//Uncaught SyntaxError: Identifier 'a' has already been declared重复声明变量报错,而var重复声明的变量不会报错
2、不存在变量提升,也就是预解析过程。只有变量声明后才可以调用,在该变量声明前使用会报错
console.log(a);//undefined var存在变量提升过程
var a = 6;
console.log(b);//ReferenceError: b is not defined不存在变量提升过程
let b = 8;
3、let声明的变量具有作用域,只在代码块内有作用域。只在块级作用域内有效。
for(let i=0;i<6;i++){
console.log(i);
}
console.log(i);//ReferenceError: i is not defined i只在for循环有效
//var声明的在全局内有效
for(var j=0;j<6;j++){
console.log(j);
}
console.log(j);//6
4、暂时性死区:只要块级作用域内存在let命令,它所声明的变量就“绑定”这个区域,在代码块内,使用let命令声明变量之前,该变量都是不可用的。
var tmp = 123;
if (true) {
tmp = 'abc'; // ReferenceError
let tmp;
}
利用let的块级作用域这一特性,可以用于for循环的计数,添加索引值以及立即执行的匿名函数不再需要了。
//a[i]为DOM元素按钮的集合,点击按钮添加事件
for (let i = 0; i < 10; i++) {
a[i].onclick = function () {
console.log(i);
};
}
2.块级作用域:主要还是通过let来实现。{}表示代码块。只在代码块内有效
{
let a=4;
}
console.log(a);//报错
3、使用const定义一个只读的常量。一旦定义不可修改。且一旦定义必须初始化。
const a=5;
a=10;//报错 TypeError: Assignment to constant variable.
const c;//报错 SyntaxError: Missing initializer in const declaration
若为引用类型,因为变量名不指向数据,只指向数据所在地址,所以const命令只是保证变量名指向的地址不变,并不保证该地址的数据不变,例如
//若为数组
const arr = [1, 2, 3];
arr.push(4);
console.log(arr); //[1,2,3,4]
arr=[1,2,3,4];//报错
//若常量为对象
const obj = {name: '123'};
obj.name = "hxc";
console.log(obj);//{name:'hxc'
obj = {name:'345'};//报错
因此在定义对象或数组常量时要格外注意。const的其他特性与let一样,只在代码块内有效,不存在变量提升,暂时性死区。
4.解构赋值:ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。ES5之前对变量复制是指定值复制例如
var a = 1;
var b = 2;
var c = 3;
而es6允许解构赋值,例如
var [a,b,c] = [1,2,3];
console.log(a,b,c); //1,2,3
var [c,d,e,f] = [1,[2],3];
console.log(c,d,e,f); //1,[2],3,undefined
数组的解构赋值是按照对应顺序结构,且允许数组嵌套,如果解构不成功则为undefined。
对象也可以解构赋值,根据对象的属性解构赋值,变量必须与对象的属性名相同。未解构到的返回undefined;与数组相同允许嵌套。
var obj = {
name: 'hxc',
age: 18
}
var {name, age}=obj;
console.log({name, age});
var {birth} = obj; //undefined
Ecmascript 6新特性的更多相关文章
- ECMAScript 6新特性简介
目录 简介 ECMAScript和JavaScript的关系 let和const 解构赋值 数组的扩展 函数的扩展 简介 ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言 ...
- ECMAScript 2021 新特性
ECMAScript 2021 新特性 refs https://codeburst.io/exciting-features-of-javascript-es2021-es12-1de8adf655 ...
- ECMAScript 6新特性(1)数组篇
数组现有的方法: .concat():连接两个或更多的数组,并返回结果. .join():把数组的所有元素放入一个字符串.元素通过指定的分隔符进行分隔. .pop():删除并返回数组的最后一个元素 . ...
- ECMAScript 6 | 新特性
新特性概览 参考文章: http://www.cnblogs.com/Wayou/p/es6_new_features.html ——————————————————————————————————— ...
- ECMAScript 6新特性介绍
箭头函数 箭头函数使用=>语法来简化函数.在语句结构上和C#.Java 8 和 CoffeeScript相似,支持表达式和函数体. . =>`操作符左边为输入的參数.而右边则是进行的操作以 ...
- ECMAScript 6新特性简记
ECMAScript 6.0是JavaScript语言的2015年6月的发布版. 一.let和const命令 let:用来声明变量,用法类似于var,但是只在let命令所在的代码块内有效. var a ...
- ECMAScript 6 新特性-set。const
一.let命令是es6新增的特性,作用与var命令类似,声明变量,不同之处在于声明的变量的作用域为块级作用域.引入let后带来了很多新的特性. 1作用域,es5之前之后函数作用域和全局作用域,let的 ...
- ECMAScript 5 新特性
Strict模式 开启strict: 在文件头部,或者在一个function头部内,添加‘use strict’或者“use strict”. Strict模式的限制,以及违反时出现的异常: 新定制了 ...
- ECMAScript 6新特性之Proxy
ECMAScript 6中新增了一个全局构造函数:Proxy.该构造函数能够接收两个參数:一个目标对象.一个处理对象. 代码演示样例: var target = {}; var handler = { ...
随机推荐
- HTML5使用jplayer播放音频、视频
首先推上神器 jPlayer:基于HTML5/Flash的音频.视频播放器 jPlayer是一个JavaScript写的完全免费和开源 (MIT) 的jQuery多媒体库插件 (现在也是一个Zepto ...
- [LeetCode] Water and Jug Problem 水罐问题
You are given two jugs with capacities x and y litres. There is an infinite amount of water supply a ...
- 当div有边框图片的时候,怎么实现内部的p标签的水平和垂直居中
<!-- 这里a.png必须是四边的框都有,限制,这个时候做里边文字的居中,首先在这个里边在套一个div悬浮(absolute或者float:left),然后在这个div(必须设宽高和margi ...
- PHP SPL(PHP 标准库)
一.什么是SPL? SPL是用于解决典型问题(standard problems)的一组接口与类的集合.(出自:http://php.net/manual/zh/intro.spl.php) SPL, ...
- mysql 多版本并发控制
查看事务隔离级别 SHOW VARIABLES LIKE "%iso%" MVCC 通过给每张表多加两个隐藏列来实现,一个保存了行的创建时间,一个保存了行的过期时间(或删除时间), ...
- Android技术分享收集
Android高工必备技能! 我的 Android 开发实战经验总结 微信Android客户端架构演进之路 微信Android版智能心跳方案 流量优化: WebP 探寻之路 HTTP 协议缓存机制详解 ...
- 链表反转leetcode206
最近准备结束自己的科研生涯,准备要开始找工作了,准备在LEETCODE刷刷题...刷的前40题全部用python刷的,各种调包速度奇快,后被师哥告知这样没意义,于是准备开始回归C++,Python用的 ...
- BZOJ 2001: [Hnoi2010]City 城市建设
2001: [Hnoi2010]City 城市建设 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 1132 Solved: 555[Submit][ ...
- UVA232
这只是大概的雏形. 步骤就是:1输入网格,2给网格里的起始格编序号,3输出所有字母,前面要加序号 #include<stdio.h> #include<ctype.h> #in ...
- thinkphp 3.2.3整合ueditor 1.4,给上传的图片加水印
今天分享一下thinkphp 3.2.3整合ueditor 1.4,给上传的图片加水印.博主是新手,在这里卡住了很久(>_<) thinkphp 3.2.3整合ueditor 1.4 下载 ...