ES6语法糖集锦
sublime3安装Es6插件
javascriptNext,然后安装即可
JavaScriptNext - ES6 Syntax()高亮插件
-----------------------------------------------------------------
let、const命令 与var声明
let块级作用域
let不允许在代码块内重复声明一个变量
function aa(){
let a=3
{
let a=5 //子作用域
}
}
使用var声明的变量,其作用域为该语句所在的函数内,且存在变量提升现象;
使用let声明的变量,其作用域为该语句所在的代码块内,不存在变量提升;
使用const声明的是常量,在后面出现的代码中不能再修改该常量的值。
-----------------------------------------------------------------
数组结构:
let [a,b,c,d] = ["aa","bb","23","44"]
对象解构
函数参数解构
-----------------------------------------------------------------
Symbol(值类型数据,唯一的)
let a = 3
let b = 3
alert(a=b) //true
-------------------
let a = Symbol(3)
let b = Symbol(3)
alert(a=b)//false
-----------------------------------------------------------------
Set
var set = new Set([1,2,3,4,5,2,8,4])//自动合并了重复值
for(var key in set){
console.log(key) //1,2,3,4,5,8
}
---------------------------------
let arr = [1,2,3,4,2,86,4]
arr.map(function(item){
set add(elem) //添加元素
})
map---->Es5语法
-----------------------------------------------------------------
WeakSet(与Set类似唯一区别就是成员只能是对象)
var weakset = new WeakSet();
-----------------------------------------------------------------
Map遍历 键可以是各种类型
let obj1 = {};
let obj2 = {};
let obj = new Object();
obj[obj1] = 33;
obj[obj2] = 66;
for(let key in obj){
console.log(key) //只循环出一个object
}
---------------------------------------
var mapData = new Map();
var obj1 = {};
var obj2 = {};
mapData.set(obj1,"22") //添加新元素
mapData.set(obj2,"22") //添加新元素
console.log(mapData.get("obj1")) //获取键
console.log(mapData.has("obj1")) //判断是否含有键
console.log(mapData.delete("obj1")) //删除键
mapData.clear() //清空
-----------------------------------------------------------------
WeakMap不可遍历没有size属性
var wm = new WeakMap();
var obj = new Object();
console.log(wm.get(obj)) //undefined
console.log(wm.has(obj)) //false
-----------------------------------------------------------------
Itrator遍历器
let arr = ["bob","pop","wow"];
let op = arr[Symbol.iterator]();
console.log(op.next());
console.log([...arr]) //依旧是数组
-----------------------------------------------------------------
Generator函数;
1.function的关键字和函数名称之间有个*号
2.函数体内可以用yield语句
3.函数调用后不会立即执行,返回的是一个遍历器对象;
function Es.(){
function *aa(){
yield"中国";
yield"美工";
yield"技术";
return "end";
}
let a = aa();
console.log(a.netx());
}
-----------------------------------------------------------------
Promise对象
三种状态:Pending(等待)、resolve(成功)、reject(失败)
异步操作解决方案,比原有的回调函数等方式更为合理
该对象改变状态只有两种可能Pending转变为resolve,Pending转变为reject;
function aa(){
function bb(){
return new Promise(function(resolve,reject){
setTimeout(function(){
console.log(123456)
},1000)
})
}
}
-----------------------------------------------------------------
async函数:(ES7)
await Promise.reject("出错了") //抛出例外,直接到例外处理处
var asyncFun = async function(){
var a1 = await function(){
setTimeout(function(){
console.log(111)
},3000)
}();
var a2 = await function(){
setTimeout(function(){
console.log(222)
},1000)
}();
console.log("执行完毕")
}
asyncFun();//先打印222再打印111;
---------------------------------
let asyncFun1 = async function(){
console.log("aaa")
return "第一个"
}
let asyncFun2 = async function(data){
console.log("bbb"+data)
return "第二个"
}
asyncFun1().then(asyncFun2).then(function(data){
console.log("这是最后执行"+data)
})
-----------------------------------------------------------------
箭头函数:(省去function关键字内部没有prototype和构造器constructor,不支持new操作,this指向会改变)
Es5写法
function a(a=6){
return a*a
}
Es6写法
let fn = (a=6)=>a*a;
console.log(fn(9));//81
Es5函数内部this不会改变,异步操作this也会改变如(async和setTimeout)
-----------------------------------------------------------------
class类(方法没有重载也就是说不可以覆盖)
class Person{
constructor(name,age,sex){
this.name = name;
this.age = age;
this.sex = sex;
}
getName(){
console.log(this.name)
}
}
let person = new Person("bob",18,"男");
person.getName();
ES6语法糖集锦的更多相关文章
- ES6 语法糖
重新认识ES6中的语法糖:https://segmentfault.com/a/1190000010159725
- es6语法糖
ES6为一些已有的功能提供了非破坏性更新,这类新语法能做的事情其实用ES5也可以做,只是会稍微复杂一些,称之为语法糖. 对象属性的简洁表示法 声明的对象中包含若干属性,其属性值由变量表示,且变量名和属 ...
- 常用处理数据用法es6 语法糖总结
一 循环(数组 ,集合) 1 forEach-----------可以遍历得到vaue和index const arr = ['red', 'green', 'blue'];arr.forEa ...
- ES6深入浅出-3 三个点运算 & 新版字符串-1.函数与对象的语法糖
主要讲的内容 时间充裕的话就讲,模板字面量 默认参数值 首先讲es6之前,我们是怎么做的.例如我们要写一个求和的函数, 请两个参数的和,但是如果有的人就是穿一个参数呢? 那么b没有传值,b的值是多少呢 ...
- ES6语法的新特性
ES6 就是ECMAScript 6是新版本JavaScript语言的标准.虽然目前已经更新到ES7,但是很多浏览器还不知处ES7语法,该标准仍在更新中,但目前部门网站都指出ES6的语法.目前ES6也 ...
- 详解es6 class语法糖中constructor方法和super的作用
大多数面向对象的编程语言都支持类和类继承的特性,而JS却不支持这些特性,只能通过其他方法定义并关联多个相似的对象,这种状态一直延续到了ES5.由于类似的库层出不穷,最终还是在ECMAScript 6中 ...
- ES6之对象的语法糖
本文介绍下ES6中对象的一些拓展功能. 这三个语法糖在实际的项目开发中经常会见到.
- ES6 class 语法糖不能直接定义原型上的属性
今天注意到两个东西: 1.为了模拟面向对象,JavaScript的class语法糖屏蔽了原型的概念 class A{ a = 1 // 注意!!这里定义的不是在prototype上的属性,而是给实 ...
- 把JavaScript代码改成ES6语法不完全指南
目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...
随机推荐
- Oracle - 数据更新 - 事务
/* 事务 事务是为了控制数据异步访问所使用的一种技术 就类似于java中的锁机制 synchronized,只不过功能更加强大 事务不能进行嵌套,当我们开启一个事务的之后作的每一次dml语句都属于这 ...
- easy_install uncompyle6 egg
localhost:~ # easy_install uncompyle6-3.0.1-py3.6.eggProcessing uncompyle6-3.0.1-py3.6.eggCopying un ...
- Extjs 3 Grid相关操作
extjs gridpanel 操作行 得到选中行的列 var model = grid.getSelectionModel(); model.selectAll(); //选择所有行 mod ...
- ubuntu /etc/profile和/etc/environment的比较 (转载)
转自:http://blog.csdn.net/teamlet/article/details/8257853 先将export LANG=zh_CN加入/etc/profile ,退出系统重新登录, ...
- POJ2823:Sliding Window
传送门 题意 有一个数列a,要求你求数列b和c,b[i]是a[i]-a[i+w-1]中的最小值,c[i]是最大值.如果a是1,3,-1,-3,5,3,6,7,则b为-1,-3,-3,-3,3,3,c为 ...
- C#中遍历ArrayList的三种方法(转)
using System; using System.Collections; using System.Linq; using System.Text; namespace ArrayListDem ...
- 洛谷P3642 [APIO2016]烟火表演
传送门 题解 fy大佬好强……我根本看不懂…… //minamoto #include<bits/stdc++.h> #define ll long long using namespac ...
- NOIp2013 货车运输 By cellur925
题目传送门 A 国有 n 座城市,编号从 1 到 n ,城市之间有 m 条双向道路.每一条道路对车辆都有重量限制,简称限重. 现在有 q 辆货车在运输货物, 司机们想知道每辆车在不超过车辆限重的情况下 ...
- python 学习笔记二 (列表推导式)
2018年年初写了第一篇博客,说要做一个认真的技术人 https://www.cnblogs.com/yingchen/p/8455507.html 今天已经是11月19日了,这是第二篇博客,看来坚持 ...
- ROS学习笔记十二:使用gazebo在ROS中仿真
想要在ROS系统中对我们的机器人进行仿真,需要使用gazebo. gazebo是一种适用于复杂室内多机器人和室外环境的仿真环境.它能够在三维环境中对多个机器人.传感器及物体进行仿真,产生实际传感器反馈 ...