首页
学习
活动
专区
工具
TVP
发布

promise详解

// 1.使用setTimeout // setTimeout(() => { // console.log(‘Hello World’); // }, 1000) // 什么情况下会用到Promise...'222') }).then(res => { console.log(res, '第三层的10行处理代码'); }) // 省略掉Promise.resolve new Promise((...'222') }).then(res => { console.log(res, '第三层的10行处理代码'); }) // 省略掉Promise.resolve new Promise((...()的使用 Promise.all([p1, p2, p3])用于将多个promise实例,包装成一个新的Promise实例,返回的实例就是普通的promise 它接收一个数组作为参数 数组里可以是Promise...对象,也可以是别的值,只有Promise会等待状态改变 当所有的子Promise都完成,该Promise完成,返回值是全部值得数组 有任何一个失败,该Promise失败,返回值是第一个失败的子Promise

66920

Promise 详解

本文旨在探讨Promise 出现背景、实现原理以及常用方法的实现。本文不是Promise的基本教程,如有不了解的读者,可以参考Promise mdn[1] 。...Promise 的出现很大程度解决上述问题。我们可以具体来看看Promise实现原理。 实现原理 Promise 主要通过以下两步来解决回调嵌套问题: 实现回调函数的延时绑定。...如果returnVal是Promise对象, 则会等该Promise对象(即returnVal)的状态发生变化才发生调用,并且新的Promise 对象状态和 returnVal状态相同。...的输入参数为 Promises数组; 其次返回对象为Promise 对象,并且返回对象Promise中的数据为执行promise 数组中的值; 如果promises 数组中1个执行失败,则返回Promise...状态和失败Promise执行状态一致。

44920
您找到你想要的搜索结果了吗?
是的
没有找到

Promise 详解

前言 PromiseJS中的一个内置类 基础写法 <!...pro = new Promise([executor]) new Promise 的时候就会把执行函数[executor]执行,[executor]是Promise类的一个回调函数,Promise...Promise不仅将它执行,还给他传递两个参数(两个参数也是函数类型) resolve函数:如果它执行,就代表Promise处理的异步事情是成功的,将Promise的状态由 padding...里的分量机制,每一次then后,都会是一个新的PROMISE实例,该实例只受上一个PROMISE实例影响(上一个实例的状态和value值来决定) 我们再来看PROMISE的玩法 如果如果当前PROMISE...创建的PROMISE实例对象来执行;如果第一个PROMISE实例它的状态修改为成功,但是第二个PROMISE实例的成功回调中处理失败,将状态改为了rejected,那么就以该报错原因作为VALUE值,.

7410

JS 手写: Promise

Promise 对象用于表示一个异步操作的最终完成 (或失败)及其结果值。 # 描述 一个 Promise 对象代表一个在这个 promise 被创建出来时不一定已知的值。...# Promise 的链式调用 我们可以用 promise.then(),promise.catch() 和 promise.finally() 这些方法将进一步的操作与一个变为已敲定状态的 promise...返回一个 promise,该 promise 在所有 promise 完成后完成。并带有一个对象数组,每个对象对应每个 promise 的结果。...# Promise.any(iterable) (opens new window) 接收一个 Promise 对象的集合,当其中的一个 promise 成功,就返回那个成功的 promise 的值。...失败,那么 Promise.all 返回的 promise 对象失败 在任何情况下,Promise.all 返回的 promise 的完成状态的结果都是一个数组 Promise.all = function

1.4K40

angularjs promise详解

一、什么是Promise Promise是对象,代表了一个函数最终可能的返回值或抛出的异常,就是用来异步处理值的。...二、为什么使用Promise 有了Promise对象,就可以把异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise对象提供了统一的接口,使得控制异步操作更加容易。...这个新的Promise对象只能观察原来Promise对象的状态,而无法修改deferred对象的内在状态可以防止任务状态被外部修改。...3.Promise API 当创建 deferred 实例时会创建一个新的 promise 对象,并可以通过 deferred.promise 得到该引用。...promise对象 when() 传入一个不确定的参数,如果符合Promise标准,就返回一个promise对象。

1K50

JS高阶(一)Promise

Promise是什么?...抽象表达: Promise是ES6中新增的规范; Promisejs中异步编程的新解决方案(旧方案采用函数回调); 具体表达: 从语法上说:Promise是一个构造函数; 从功能上说:Promise...promise 对象; 说明:返回一个成功/失败的 promise 对象; //创建promise.resolve对象 //如果传入的对象为 非promise对象 则返回的是一个 成功的promise...对象; 说明:只返回一个失败的 promise 对象; //创建promise.resolve对象 //如果传入的对象为 非promise对象 则返回的是一个 成功的promise对象 //如果传入的对象...非promise对象 则参数的结果决定了 resolve的结果 let p = Promise.reject(521); let c = Promise.reject(new Promise(

2.4K10

怎么理解JS Promise

四、Promise与异步 Promise是异步的。js异步操作是通过js的事件循环机制EventLoop实现的。...对于异步任务来说,当其可以被执行时,会被放到一个 任务队列(task queue) 里等待JS引擎去执行。...当执行栈中的所有同步任务完成后,JS引擎才会去任务队列里查看是否有任务存在,并将任务放到执行栈中去执行,执行完了又会去任务队列里查看是否有已经可以执行的任务。...总结起来js引擎对程序的执行顺序是:1。先执行同步任务的程序 2。 在执行异步任务里的微任务 3。所有微任务都执行完了后就执行异步的宏任务,但这里是一个一个宏任务去执行,不是一下子执行完。...after");//同步任务 } testFn(); 上图结果证明了上述所说的js的执行顺序 。

11.6K30

Promise用法详解(一)

Promise 基本概念 Promise是一个构造函数,所以可以 new 出一个Promise的实例 在Promise上有两个函数 resolve(成功之后的回调函数)和 reject(失败后的回调函数...所以只要是Promise构造函数创建的实例,都可以访问到 .then()方法 Promise表示一个一步操作,每当我们new一个Promise的实例,这个实例就代表具体的异步操作。...我们可以在new出来的Promise实例上,调用 .then()方法,预先为这个Promise异步操作,指定成功(resolve)和失败(reject)回调函数 形式上和具体的Promise异步操作的区别...Promise的执行时机 每当new一个Promise实例的时候,除了会得到一个promise实例之外,还会立即调用我们为Promise构造函数传递的那个function,执行function中的异步代码...此时可以使用 .catch()进行异常捕获,只要前面Promise有任何一个执行失败,立即终止所有的Promise的执行,并马上进入catch中去处理Promise中抛出的异常。

30320

JS 异步系列 —— Promise 札记

Promise; 要了解其它更为高级的异步操作得先熟悉 Promise; 基于这些目的,实践了一个符合 Promise/A+ 规范的 repromise。...本札记系列总共三篇文章,作为之前的文章 Node.js 异步异闻录 的拆分和矫正。...Promise札记 Generator札记 Async札记 Promise/A+ 核心 在实现一个符合 Promise/A+ 规范的 promise 之前,先了解下 Promise/A+ 核心,想更全面地了解可以阅读...; Promise 的状态一旦转化,将不能被更改; repromise api 食用手册 Promise.resolve() Promise.resolve() 括号内有 4 种情况 /* 跟 Promise...(),Promise.reject() 原封不动地返回参数值 Promise.all(arr) 对于 Promise.all(arr) 来说,在参数数组中所有元素都变为决定态后,然后才返回新的 promise

1.1K30

promise源码详解,助力你轻松掌握promise

{ //因为在.then之后又是一个promise对象,所以这里肯定要返回一个promise对象 promise2 = new Promise((resolve,reject)=...:这其实是官方Promise/A+的需求。因为你的then可以返回任何职,当然包括Promise对象,而如果是Promise对象,我们就需要将他拆解,直到它不是一个Promise对象,取其中的值。...function resolvePromise(promise2,x,resolve,reject){ //判断x和promise2之间的关系 //因为promise2是上一个promise.then...:相信细心的人已经发现了,我这里使用了递归调用法,首先这是Promise/A+中要求的,其次是业务场景的需求,当我们碰到那种Promise的resolve里的Promise的resolve里又包了一个Promise...结尾 今天给大家分析promise的基本用法,以及promise的实现和用它解决什么问题,希望大家可以更好的理解和掌握promise,是自己的技术得到进一步的提升!

95610

promise源码详解,助力你轻松掌握promise

{ //因为在.then之后又是一个promise对象,所以这里肯定要返回一个promise对象 promise2 = new Promise((resolve,reject)=...:这其实是官方Promise/A+的需求。因为你的then可以返回任何职,当然包括Promise对象,而如果是Promise对象,我们就需要将他拆解,直到它不是一个Promise对象,取其中的值。...function resolvePromise(promise2,x,resolve,reject){ //判断x和promise2之间的关系 //因为promise2是上一个promise.then...:相信细心的人已经发现了,我这里使用了递归调用法,首先这是Promise/A+中要求的,其次是业务场景的需求,当我们碰到那种Promise的resolve里的Promise的resolve里又包了一个Promise...结尾 今天给大家分析promise的基本用法,以及promise的实现和用它解决什么问题,希望大家可以更好的理解和掌握promise,是自己的技术得到进一步的提升!

48850

JSpromise是什么?

所谓的Promise,简单的来说就是一个可以存放未来才能结束的任务或者事件。 1....Promise实列有三个状态: – pending (进行中) – resolved (成功) – rejected(失败) 当要处理某个任务的时候,promise的状态是pending,任务完成是状态就变成了...3.all() 接受一个数组作为自己的参数,数组中每一项都是一个promise对象,当数组的每一个promise状态时resolved时,all方法的状态才会变成resolved,有一个变成rejected...5finally() 他是不管promise时什么状态都会执行的都会去执行的,他不接受任何的参数。 Promise的优点: – 对象的状态不受外界的影响,只有异步的操作结果才能改变他的状态。...– 一旦状态改变就不会在变,任何时候都可以得到这个结果,就如他的名字一样promise(承诺)。 Promise的缺点: – 无法去取消promise,只要创建就会执行,无法中途去终止。

3.7K10
领券