我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

es6的promise怎么使用

今天小编给大家分享一下es6的promise怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

创新互联制作网站网页找三站合一网站制作公司,专注于网页设计,成都网站设计、成都做网站、外贸网站建设,网站设计,企业网站搭建,网站开发,建网站业务,680元做网站,已为上1000家服务,创新互联网站建设将一如既往的为我们的客户提供最优质的网站建设、网络营销推广服务!

在es6中,promise是“承诺”的意思,承诺表示异步操作的结果,是新增的异步编程解决方法,在代码中表现为一个对象,主要用于解决回调地域问题,语法为“new Promise(function(resolve, reject){..})”。

本教程操作环境:windows10系统、ECMAScript 6.0版、Dell G3电脑。

es6的promise是什么意思

promise 是承诺的意思,其背后的核心思想是,承诺表示异步操作的结果。

是es6新增的异步编程解决方案,在代码中表现为一个对象。

promise是js异步编程提供的解决方案,主要用来解决回调地域问题。

Promise有三种状态,分别是

  • Pending(进行中) 初始状态

  • Fulfilled (已成功) 意味着操作成功

  • rejected (已失败) 意味着操作失败

注意:Promise对象的三种状态,不受外界的影响,只有promise中存放的将来会结束的事件才会影响。也就是只有异步操作的结果,可以决定当前是哪一种状态,任何其他操作都无法改变这个状态

Promise状态一旦改变、不可逆

Pendding(进行中)状态可以转变为Fulfilled(已成功)状态

Pendding(进行中)状态可以转变为 rejected(已失败)状态

promise只有这两种情况发生状态改变,一旦发生这两种状态改变,那么状态就凝固了,会一直保持这个结果。

基本使用方法

语法:

new Promise( function(resolve, reject) {...} /* executor */  )

原理:

构建 Promise 对象时,需要传入一个 executor 函数,主要业务流程都在 executor 函数中执行。

Promise构造函数执行时立即调用executor 函数, resolve 和 reject

两个函数作为参数传递给executor,resolve 和 reject

函数被调用时,分别将promise的状态改为fulfilled(完成)或rejected(失败)。一旦状态改变,就不会再变,任何时候都可以得到这个结果。

在 executor 函数中调用 resolve 函数后,会触发 promise.then 设置的回调函数;而调用 reject

函数后,会触发 promise.catch 设置的回调函数。

如下图所示:

es6的promise怎么使用

示例如下:

创建一个新的Promise对象

需要传入一个回调函数,回调函数有2个参数,分别代表resolve(解决),reject(拒绝),并且两个参数都是函数

如果两个参数都不调用,默认pending状态

let promise=new Promise(function(resolve,reject){
});//pending状态

调用resolve 函数,代表Promise的状态,会从pending==>fulfilled

let promise=new Promise(function(resolve,reject){
resolve();
});//fulfilled状态

调用reject函数,代表Promise的状态,会从pending==>rejected

let promise=new Promise(function(resolve,reject){
reject();
});//rejected 状态

以上就是“es6的promise怎么使用”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注创新互联行业资讯频道。


网站题目:es6的promise怎么使用
文章链接:http://mswzjz.cn/article/iepepo.html

其他资讯