ES6语法 Promise Iterator
类和对象
基本定义:
class Parent{
constructor(name='lmx'){ //name= 默认值
this.name=name
}
}
let v_parent = new Parent('v');
console.log(v_parent);
//输出Parent {name: "v"}
继承
class Parent{
constructor(name='lmx'){
this.name=name
}
}
class Child extends Parent{
constructor(name=’child’){
super(name); //如果super中没有参数则都按照父类的默认值
}
}
console.log(new Child())
getter和setter
class Parent{
constructor(name='lmx'){
this.name=name
}
}
get longName(){
return ‘mk’+this.name;
}
set longName( val){
this.name = val
}
let v = new Parent();
console.log(v.longName()) //调用get方法
v.longName = ‘hello’ //调用set方法
console.log(v.longName())
静态方法:static定义的是类的方法只有类能调用
class Parent{
constructor(name='lmx'){
this.name=name
}
static tell(){
console.log(‘tell’)
}
Parent.tell()
}
静态属性:
ES6明确规定,Class内部只有静态方法,没有静态属性,但是可以通过 类名.变量 来定义
class Parent{
constructor(name='lmx'){
this.name=name
}
}
Parent.abc=’123’
Promise
Promise.all([ ]).then() 表示把多个Promise实例当做一个Promise实例,当所有Promise实例状态发生改变之后,新的Promise才能发生改变,即当三个loadImg实例都加载完之后才会触发Promise.all方法,才会then,才执行showImg
//所有图片加载完了之后才一起显示
function loadImg(src){
return new Promise((resolve,reject)=>{
let img = document.createElement('img');
img.src= src;
img.onload = function(){ resolve(img) };
img.onerror = function(){ reject(err)}
})
}
function showImg(imgs){
imgs.forEach(item=>{
document.body.appendChild(item)
})
};
Promise.all([
loadImg('http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg'),
loadImg('http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg'),
loadImg('http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg')
]).then(showImg)
Promise.race ([ ]).then() 多个实例中有一个状态率先改变之后,race实例会改变,其他的便忽略不管了
//只要有图片加载出来了就显示
function loadImg(src){
return new Promise((resolve,reject)=>{
let img = document.createElement('img');
img.src= src;
img.onload = function(){ resolve(img) };
img.onerror = function(){ reject(err)}
})
}
function showImg(imgs){
imgs.forEach(item=>{
document.body.appendChild(item)
})
};
Promise.race([
loadImg('http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg'),
loadImg('http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg'),
loadImg('http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg')
]).then(showImg)
Iterator接口
在数组中的应用
let arr = ['hello','world'];
let map = arr[Symbol.iterator]();
console.log(map.next());
console.log(map.next());
console.log(map.next());
//输出,done变为true之后循环截止

自定义iterator接口
for...of循环
let obj = {
start:[3,5,6],
end:[4,8,9],
[Symbol.iterator](){ //iterator小写
let self= this;
let index = 0;
let arr = self.start.concat(self.end);
let len = arr.length;
return{
next(){
if(index<len){
return {
value:arr[index++],
done:false}
}else{
return {
value:arr[index++],
done:true
}
}
}
}
}
} ;
for(let key of obj){
console.log(key)
}

ES6语法 Promise Iterator的更多相关文章
- ES6语法 promise用法
ES6语法 promise用法 function doSomething(){ return new Promise((resolve,reject)=>{ resolve('jjjj');// ...
- es6 语法 (iterator和for...of循环)
Iterator遍历器 遍历器(Iterator)就是这样一种机制.它是一种接口,为各种不同的数据结构提供统一的访问机制.任何数据结构只要部署Iterator接口,就可以完成遍历操作(即依次处理该数据 ...
- ES6语法——Promise对象
一.概念 Promise是异步编程的一种解决方案(解决回调地狱的问题),是一个能够获取异步操作信息的对象.Promise的内部保存着某个未来才会结束的事件(通常是一个异步操作) 二.特点 1.Prom ...
- vuex+Es6语法补充-Promise
Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式,采用 集中式存储管理 单页面的状态管理/多页面状态管理 使用步骤: // 1.导入 import Vuex from 'vuex' // ...
- ES6语法知识
let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的 ...
- ES6之Promise用法详解
一 前言 本文主要对ES6的Promise进行一些入门级的介绍.要想学习一个知识点,肯定是从三个方面出发,what.why.how.下面就跟着我一步步学习吧~ 二 什么是Promise 首先是what ...
- 常用的ES6语法
1. let.const 和 block 作用域 let 允许创建块级作用域,ES6 推荐在函数中使用 let 定义变量,而非 var: var a = 2; { let a = 3; console ...
- 把JavaScript代码改成ES6语法不完全指南
目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...
- 在Node中使用ES6语法
Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把E ...
随机推荐
- background-image属性
background-image 属性 实例,设置body元素的背景图像: body { background-image: url('paper.gif'); background-color: # ...
- linux 修改history带有时间
今天在网上学到了给linux的history添加时间.方法如下: 首先已知HISTTIMEFORMAT可以给history设置时间:临时修改直接赋值:HISTTIMEFORMAT="%F % ...
- cc.Node 的坐标空间与ACTION的学习
1.创建二维的向量坐标 //创建向量坐标方法一 let new_pos1 = new cc.Vec2(100, 100); //创建向量坐标方法二 let new_pos2 = cc.v2(200, ...
- 分享一个学习的网站:每天会有大量AI相关的干货(论文分享,行业动态,相关竞赛经验分享等)http://www.deepsmart.ai/
网址:http://www.deepsmart.ai/ 微信公众号如下:
- IDEA手动创建JFinal项目
http://www.jfinal.com/share/674 https://www.oschina.net/question/265150_110300
- LeetCode545.Boundary-of-Binary-Tree
1.头节点为边界节点 2.叶结点为边界节点 3.如果节点在其所在的层中是最左边或最右边,那么也是边界节点. 思路:分成三部分来做:找左边界结点.叶结点.右边界结点. 找左边界结点要遍历root的左子树 ...
- 指针数组&数组指针
数组指针(也称行指针) 定义 int (*p)[n]; ()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数 ...
- UOJ#314. 【NOI2017】整数 其他
原文链接https://www.cnblogs.com/zhouzhendong/p/UOJ314.html 题解 如果只加不减,那么瞎势能分析一波可以知道暴力模拟的复杂度是对的. 但是有减法怎么办? ...
- Intellij IDEA导入eclipse项目配置jdk、tomcat到浏览器正常访问
转发自:博客园---Lindp(大佬写的甚好) 以下是转发的正文 intellij idea中文资料网上比较少,对于eclipse的项目如何导入intellij idea也没有完整的说明,本人在这里整 ...
- 关于UTF-8和GBK编码的转换
$oldname=mb_convert_encoding($_POST['oldname'], "GBK" , "UTF-8");//将变量转码为GBK,已知原 ...