首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript手写Promise、Promise.then()、Promise.all()、Promise.race()

    的resolve,让其状态变更,这又会依次调用新Promise的callbacks数组里的方法,循环往复。...,因为每次then都返回新的Promise实例 注册完成后开始执行构造函数中的异步事件,异步完成之后依次调用callbacks数组中提前注册的回调 手写Promise.all 接收一个Promise实例的数组或具有...,返回值数组与参数顺序一致 参数数组其中一个失败,则触发失败状态,第一个触发失败状态的Promise错误信息作为Promise.all的错误信息 function promiseAll(promises...该方法的参数是Promise实例数组,然后其then注册的回调方法是数组中的某一个Promise的状态变为fufilled的时候执行。...因为Promise的状态只能改变一次,那么我们只需要把Promise.race中产生的Promise对象的resolve,注入到数组中的每一个Promise实例中的回调函数即可。

    97910

    Promise

    Promise构造函数执行时立即调用executor函数,resolve和reject两个函数作为参数传递给executor(executor函数在Promise返回所建promise实例对象前被调用)...executor内部通常会执行一些异步操作,一旦异步操作执行完毕(成功/失败)要么调用resolve函数来将promise状态改成fulfilled,要么将promise函数将状态改为rejected。...---- 2.描述 promise对象是一个代理对象(代理一个值),被代理的值在Promise对象创建时可能是未知的。它允许你对异步操作的成功和失败分别绑定对应的处理方法。...一个promise有以下几种状态: pending :初始状态 fulfilled:操作成功完成 rejected: 操作失败 ---- 3.创建Promise 想要某个函数拥有promise函数...,只需让其返回一个promise即可 function myAsyncFun(url){ return new Promise((resolve, reject)=>{ const xhr

    70520

    Promise

    Promise Promise对象用于呈现异步操作事件的完成/失败结果。 此篇文章翻译自Promise,原文章太长,因此自己在这里做了简化,以便自己加强认识和理解。...上述两种情况发生时候,通过promise的then()方法关联的响应器 [promise states] 链式Promises 当一个promise处于settled状态时,promise.then()...(iterable) 等待可迭代对象中的promise对象都被resolved或rejected, 如果全部都是resolved,则它的resolve handler的入参是一个数组,该数组的值是所有promise...(iterable) 和Promise.all(iterable)类似,等待所有的promise对象都被settled,但其入参是一个数组,数组中包含所有promise对象的执行结果(不区分对待fulfilled...(reject, 100, 'foo')); const promises = [promise1, promise2]; // results入参是一个数组 Promise.allSettled(promises

    70250

    数组的遍历你都会用了,那Promise版本的呢

    但是在对数组进行一些遍历操作时,发现有些遍历方法对Promise的反馈并不是我们想要的结果。 当然,有些严格来讲并不能算是遍历,比如说some,every这些的。...但确实,这些都会根据我们数组的元素来进行多次的调用传入的回调。 这些方法都是比较常见的,但是当你的回调函数是一个Promise时,一切都变了。...) // 对数组元素进行求平方 // > [Promise, Promise, Promise] 这时候,我们获取到的返回值其实就是一个由Promise函数组成的数组了。...所以为什么上边说map函数为最友好的,因为我们知道,Promise有一个函数为Promise.all 会将一个由Promise组成的数组依次执行,并返回一个Promise对象,该对象的结果为数组产生的结果集...await Promise.all([1, 2, 3].map(async item => item ** 2)) // > [1, 4, 9] 首先使用Promise.all对数组进行包装,然后用await

    77320

    数组的遍历你都会用了,那Promise版本的呢

    但是在对数组进行一些遍历操作时,发现有些遍历方法对Promise的反馈并不是我们想要的结果。 当然,有些严格来讲并不能算是遍历,比如说some,every这些的。...但确实,这些都会根据我们数组的元素来进行多次的调用传入的回调。 这些方法都是比较常见的,但是当你的回调函数是一个Promise时,一切都变了。...) // 对数组元素进行求平方 // > [Promise, Promise, Promise] 这时候,我们获取到的返回值其实就是一个由Promise函数组成的数组了。...所以为什么上边说map函数为最友好的,因为我们知道,Promise有一个函数为Promise.all 会将一个由Promise组成的数组依次执行,并返回一个Promise对象,该对象的结果为数组产生的结果集...await Promise.all([1, 2, 3].map(async item => item ** 2)) // > [1, 4, 9] 首先使用Promise.all对数组进行包装,然后用await

    1.3K40

    Promise

    1.Promise的立即执行性 var p = new Promise(function(resolve, reject){ console.log("create a promise"); resolve...); 控制台输出: "create a promise" "after new Promise" "success" Promise对象表示未来某个将要发生的事件,但在创建(new)Promise时,作为...有些同学会认为,当Promise对象调用then方法时,Promise接收的函数才会执行,这是错误的。因此,代码中"create a promise"先于"after new Promise"输出。...当Promise刚创建完成时,处于pending状态;当Promise中的函数参数执行了resolve后,Promise由pending状态变成resolved状态;如果在Promise的函数参数中执行的不是...return 另一个 Promise,then方法将根据这个Promise的状态和值创建一个新的Promise对象返回。

    60720

    Promise

    ——简嫃 在前端开发中经常会使用异步方法 这里介绍Promise函数 定义方式: // Promise内部构造参数为一个闭包,闭包中传入你想要异步处理的逻辑 new Promise((resolve...reject则是异常逻辑或错误逻辑时执行,当异步方法中抛出异常,会自动调用reject,这里也可以手动调用 resolve(1) }) 然后定义完了,我们就可以开始调用 调用写法如下: new Promise...=>{ console.log(res+1) }).catch(error=>{ console.log(error) }) 打印结果为ruben 我们也可以用另一种写法: new Promise...,第二个则相当于`catch`函数的参数 .then(res=>{ console.log(res+1) },error=>{ console.log(error) }) 如果我们对于Promise...要让他同步处理,也就是说我要等他执行完再执行后面的逻辑,可以在前面加一个await await new Promise((resolve,reject)=>{ throw new Error("

    36720
    领券