一、Promise介绍
1、Promise简单说就是一个容器,里面保存着某个未来才会结束的事件(通常是一个异步操作)的结果
2、Promise可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise对象提供统一的接口,使得控制异步操作更加容易

二、基本用法【使用时注意环境及异步操作相关包安装】
在node环境中使用ajax时需要安装jsdom、jqury包
配置常量:

    //创建window环境
const {JSDOM} = require('jsdom');
const {window} = new JSDOM('<!DOCTYPE html>');
//获取jQuery函数
const $ = require('jquery')(window);

1、Promise构造函数接受一个函数作为参数,该函数的两个参数分别是resolve函数和reject函数【参数函数由JavaScript引擎提供,不用自己部署】
eg:

    let promise = new Promise((resolve,reject)=>{});

a、resolve函数的作用:
将Promise对象的状态从“未完成”变为“成功”【从Pending 变为 Resolved】,在异步操作成功时调用,并将异步操作的结果,作为参数传递出去

b、reject函数的作用:
将Promise对象的状态从“未完成”变为“失败”【从 Pending 变为 Rejected】,在异步操作失败时调用,并将异步操作报出的错误,作为参数传递出去

Promise实例生成以后,可以使用实例then方法分别指定Resolved状态和Rejected状态的回调函数【一般建议使用then和catch分开指定回调函数】

then(fun1,fun2)
方法参数:
a、fun1:Promise对象的Resolved状态回调函数
b、fun2:Promise对象的Rejected状态回调函数

catch(fun)   【该方法为then(null,fun2)方法的别名】
方法参数:
fun:Promise对象的Rejected状态回调函数

注:
一般使用then来执行Resolved状态回调函数,使用catch来执行Rejected状态回调函数,而不直接使用then调用两种状态下的回调函数

finally(fun)    【不管Promise对象状态如何,都会执行该方法】(一般用于回收资源)
eg:

    let promise = new Promise((resolve,reject)=>{
//参数函数内部一般执行异步操作
$.ajax({
url:'',
method:'',
data:[],
success(res){
resolve(res);
},
error(error){
reject(error);
}
});
});
//执行Promise构造函数中异步执行成功resolve()方法的回调函数
promise.then((res)=>{});
//执行Promise构造函数中异步执行失败reject()方法的回调函数
promise.catch((error)=>{});
//不管Promise对象状态如何,都会执行该方法
promise.finally(()=>{});
//上面方法也可以使用下面形式调用
//promise.then((res)=>{}).catch((error)=>{}).finally(()=>{});

三、Promise函数相关方法
1、Promise. resolve()
参数类型:
a、参数是一个Promise实例    【返回这个Promise实例】
eg:

    //传递的是Promise对象,不做任何操作,原样返回这个Promise实例promise
let p = Promise.resolve(promise); p.then((res)=>{
console.log(res);
}).catch((error)=>{
console.log(error,'-------');
}).finally(()=>{
//无论异步操作成功或失败都会执行finally函数
console.log('finally');
});

b、参数是一个thenable对象【thenable对象指的是具有then方法的对象】
Promise.resolve方法会将这个thenable对象转为Promise对象,然后就立即执行这个thenable对象的then方法
eg:

    let obj = {
name:'zhangsan',
then(){
console.log('obj中的then方法');
}
}; let p = Promise.resolve(obj); //直接执行obj对象中的then方法,不会执行实例对象p中的then方法
p.then(()=>{ //该方法不会执行
console.log('p3的then方法');
});

c、参数不是一个thenable的对象或根本就不是对象    【返回一个新的Promise对象,状态为Resolved,执行then中的回调函数】
eg:

    //执行了resolve函数,即执行then中的回调函数【执行了resolve函数,Promise对象才由pending状态转化为resolve状态】
let p = Promise.resolve('hello'); //返回resolve状态的Promise对象【内部执行了resolve函数】 打印resolve字符串
p.then(()=>{
console.log('resolve');
}).catch(()=>{
console.log('reject');
});

d、不带有任何参数    【返回一个Resolved状态的Promise对象】

2、Promise.all()    【返回多个Promise实例包装成的一个新Promise实例】
方法参数:
参数为多个Promise实例对象组成的数组
方法说明:
a、将多个Promise实例,包装成一个新的Promise实例,并返回该新包装的Promise实例
b、若参数数组中的所有Promise实例状态为resolved时,新包装的实例状态才为resolve状态,
新包装的实例then方法中的resolve的回调函数参数数据信息为所有实例返回的成功请求数据
c、若参数数组中碰到有Promise实例状态为rejected时,新包装的实例状态即为rejected状态,无需再看后面的实例状态,
新包装的实例catch方法中的reject的回调函数参数数据信息为该rejected状态实例参数的失败请求数据
eg:

    //p1,p2,p3为Promise的实例对象
var p = Promise.all([p1, p2, p3]); //新实例p的状态为数组参数中返回信息结果最快的实例状态【即参数数组获取信息最快的实例对象】
p.then((res)=>{
console.log(res); //p1,p2,p3中resolved状态返回的信息集合对象
}).catch((error)=>{
console.log(error) //参数最先配到的实例rejected状态的返回信息
});

3、Promise.race()    【返回多个Promise实例包装成的一个新Promise实例】
方法参数:
参数为多个Promise实例对象组成的数组
方法说明:
a、新包装的Promise实例状态为参数数组中返回信息结果最快的实例对象的状态
b、新包装的Promise实例相应方法中的数据信息即为参数数组中返回信息最快的实例相关数据信息
eg:

    //p1,p2,p3为Promise的实例对象
var p = Promise.race([p1, p2, p3]); //新实例p的状态为数组参数中返回信息结果最快的实例状态【即参数数组获取信息最快的实例对象】
p.then((res)=>{
console.log(res); //参数数组中执行最快的实例返回的成功数据信息
}).catch((error)=>{
console.log(error) //参数数组中执行最快的实例返回的失败数据信息
});

ES6 Promise对象(七)的更多相关文章

  1. ES6 Promise对象then方法链式调用

    then()方法的作用是Promise实例添加解决(fulfillment)和拒绝(rejection)状态的回调函数.then()方法会返回一个新的Promise实例,所以then()方法后面可以继 ...

  2. ES6 Promise 对象

    Promise 的含义 Promise 是异步编程的一种解决方案,比传统的解决方案--回调函数和事件--更合理和更强大.它由社区最早提出和实现,ES6 将其写进了语言标准,统一了用法,原生提供了Pro ...

  3. JavaScript ES6 Promise对象

    说明 Node.js中,以异步(Async)回调著称,使用了异步,提高了程序的执行效率,但是,代码可读性较差的. 假如有几个异步操作,后一个操作需要前一个操作的执行完毕之后返回的数据才能执行下去,如果 ...

  4. es6 promise对象

    function next(){ return new Promise( function( resolve, reject ){ var num =7 // Math.floor( Math.ran ...

  5. IE不支持 ES6 Promise 对象的解决方案

    * 引入bluebird.js即可完美解决. /*ie兼容 Promise*/ isIE(); function isIE() { //ie? if ( !! window.ActiveXObject ...

  6. ES6 Promise 全面总结

    转载:点击查看原文 ES6 Promise对象 ES6中,新增了Promise对象,它主要用于处理异步回调代码,让代码不至于陷入回调嵌套的死路中. @-v-@ 1. Promise本质 Promise ...

  7. ES6 之 let和const命令 Symbol Promise对象

    ECMAScript 6入门 ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了. (2016年6月,发布了小幅修订的<ECMASc ...

  8. ES6深入学习记录(二)promise对象相关

    1.Promise的含义 Promise是异步编程的一种解决方案,比传统的解决方案--回调函数和事件更合理和强大.ES6将其写进了语言标准,统一了用法,原生提供了promise对象. 所谓Promis ...

  9. es6中的promise对象

    Promise是异步里面的一种解决方案,解决了回调嵌套的问题,es6将其进行了语言标准,同意了用法,提供了`promise`对象, promise对象有三种状态:pending(进行中) .Resol ...

随机推荐

  1. 吴丽丽-201871010123 《面向对象程序设计(java)》第六、七周学习总结

    吴丽丽-201871010123 <面向对象程序设计(java)>第六.七周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh ...

  2. vs在matlab生成的dll中,load treebigger错误

    提示的错误:Warning: Variable 'model' originally saved as a TreeBagger cannot be instantiated as an object ...

  3. GDB 调试C++

    原来比较熟悉用gdb调试C程序,没有用过gdb调试C++程序,原理上没有什么区别.在形式上有一些区别,因为C++支持名字空间和class等机制,把函数的可见域做了隔离. 拿envoy的代码作个例子: ...

  4. Codeforces Round #530 (Div. 2) F 线段树 + 树形dp(自下往上)

    https://codeforces.com/contest/1099/problem/F 题意 一颗n个节点的树上,每个点都有\(x[i]\)个饼干,然后在i节点上吃一个饼干的时间是\(t[i]\) ...

  5. Codeforces Round #549 (Div. 2) D 数学

    https://codeforces.com/contest/1143/problem/D 题意 有nk个城市,第1,k+1,2k+1,...,(n-1)k+1城市有餐厅,你每次能走l距离,a为起始位 ...

  6. 【转】spring的AOP原理,使用场景是什么?

    什么是AOP AOP(Aspect-OrientedProgramming,面向方面编程),可以说是OOP(Object-Oriented Programing,面向对象编程)的补充和完善.OOP引入 ...

  7. 来吧!一文彻底搞定Vue组件!

    作者 | Jeskson 来源 | 达达前端小酒馆 Vue组件的概述 组件是什么呢,了解组件对象的分析,Vue组件中的data属性,props传递数据的原理到底是什么. 事件通信的那些事 如何了解父子 ...

  8. C# HTTP系列9 GET与POST示例

    系列目录     [已更新最新开发文章,点击查看详细] 学习本篇之前,对 HttpWebRequest 与 HttpWebResponse 不太熟悉的同学,请先学习<C# HTTP系列>. ...

  9. PurpleAir空气质量数据采集

    PurpleAir空气质量数据采集 # -*- coding: utf-8 -*- import time, datetime, calendar import urllib, requests im ...

  10. golang strings常用函数

    package main import ( "fmt" "strings" ) func main() { s1 := " aBc" s2 ...