当前位置: 首页 > news >正文

做影视网站赚钱百度竞价排名公司

做影视网站赚钱,百度竞价排名公司,手机端网站开发,阿里云域名注册续费简介: Promise.all是JavaScript中一种用于处理多个Promise对象的方法,该方法接收一个数组作为参数,并返回一个新的Promise对象。 这个新的对象会在所有Promise对象都成功解析后解析,解析的结果是一个数组,包含了所有P…

简介:

  • Promise.all是JavaScript中一种用于处理多个Promise对象的方法,该方法接收一个数组作为参数,并返回一个新的Promise对象。

  • 这个新的对象会在所有Promise对象都成功解析后解析,解析的结果是一个数组,包含了所有Promise对象解析后的结果。

  •  解析时如果任何一个Promise对象失败,则这个新的Promise实例会立即失败,并返回第一个失败的Promise对象的错误信息。

  • Promise.all不会改变原有的Promise对象的状态,原有的 Promise 对象仍会按照自己的状态(fulfilled或rejected)进行解析。

那么Promise.all的具体实现过程是怎样的?今天来记录学习下,话不多说,直接上代码和注释,

// 手写Promise.all方法
Promise.myPromiseAll = function (props) {// 这里定义res、rej变量,在Promsie内部赋值,// 这样外部就可以直接调用res()、rej()方法let res, rej;// 这里定义promise1,用于最后返回最终状态const promise1 = new Promise((resolve, reject) => {res = resolve;rej = reject;});//定义i 表示Promise对象的数量let i = 0;// 定义result 用于存储每个成功Promise的结果const result = [];//定义fulfilled 用于追踪已完成的Promise数量let fulfilled = 0;// 这里不能使用.length判断props数组长度,因为他有可能是一些别的可迭代对象,// 所以这里使用for of循环Promise的参数props,for of可以循环任意的可迭代对象for (const item of props) {// 这里保存的数据下标index,用于赋值成功后的data数据,形成闭包环境const index = i;// 这里每循环一次i加1,表示Promise数量i++;// 这里循环拿到的不一定是一个Promise,所以使用Promise.resolve包装一下,// 然后处理成功和失败的状态Promise.resolve(item).then((data) => {// 这里需要考虑到Promise成功时需要做到什么?1、2、// 1、完成的数据汇总到一个数组,最终结果// 在上面定义result,于存储每个成功Promise的结果,// 这里不能使用push方法,因为我们需要返回的数据是传递的顺序,不是完成的顺序// 所以这里根据下标赋值成功后的data数据result[index] = data;// 2、判定是否全部完成// 这里在上面定义fulfilled,记录每次完成fulfilled数量加1fulfilled++;// 这里判断fulfilled完成的数量和Promise数量相等时表示结束,// 把数据result给resif (fulfilled === i) { res(result); }// 这里如果失败,直接调用失败的方法,因为状态一旦确定就无法更改}, rej)// 因为这里是异步代码,运行时循环已经结束,所以i代表的一定是整体的数量}// 这里循环完成,判断i如果等于0,表示没有传递任何Promise参数// 直接给一个空数组if (i === 0) { res([]); }// 最后直接返回最终状态promise1return promise1;
}Promise.myPromiseAll([]).then((res) => {console.log(res);
}, (err) => {console.log("err", err);
})
// 输出 []Promise.myPromiseAll([1, 2, 3]).then((res) => {console.log(res);
}, (err) => {console.log("err", err);
})
// 输出 [1, 2, 3]Promise.myPromiseAll([1, 2, 3, Promise.reject(456)]).then((res) => {console.log(res);
}, (err) => {console.log("error", err);
})
// 输出 error 456Promise.myPromiseAll([1, 2, 3, Promise.resolve(456)]).then((res) => {console.log(res);
}, (err) => {console.log("err", err);
})
// 输出 [ 1, 2, 3, 456 ]

http://www.zhongyajixie.com/news/3697.html

相关文章:

  • 做视频的网站跨境电商平台推广
  • 登封seo推广通州优化公司
  • 辽宁响应式网站建设长清区seo网络优化软件
  • 做论坛网站如何赚钱的自助建站seo
  • 网页游戏网址推荐武汉seo群
  • 给人做代工的网站最近的新闻热点
  • 电子工厂网站建设什么是seo文章
  • 山东做网站建设公司网站关键词上首页
  • 山东疫情最严重的地方是哪里杭州百度首页优化
  • 宿州网站建设费用西安关键词优化平台
  • 高级web程序设计:jsp网站开发公司网站模版
  • asp网站建设实例花炮软文广告经典案例100字
  • 手机网站开发兼容性软文范例100字以内
  • 怎么创建个人的网站网络推广推广培训
  • 网站cps后台怎么做网络推广方法的分类
  • 用网站做淘宝客怎么样个人如何建立免费网站
  • 网站开发与编程如何用模板做网站
  • 南昌做网站开发的公司有哪些网页制作接单
  • 湖北黄冈疫情最新情况seo网站优化培训怎么样
  • 青岛网站建设有哪些公司优化快速排序
  • 杭州做小程序软件的公司长沙优化科技有限公司
  • 2017两学一做网站广告宣传语
  • 抽奖机网站怎么做搜索引擎大全排行
  • 不建网站网络营销怎么做北京培训学校
  • 交做网站视频百度云免费网站推广网站在线
  • 网站设置点赞杭州seo网站排名
  • 网站后台查询软件seo咨询师
  • 长春市住房城乡建设委官方网站外贸推广平台哪个好
  • 网站标题改不了seo排名优化推荐
  • 建设购物网站需要多少费用外包公司是正规公司吗