Promise 异步函数顺序执行

Posted 麦君

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Promise 异步函数顺序执行相关的知识,希望对你有一定的参考价值。

可以满足需求,且使用方法和Promise.all统一

var a = function() {
    return new Promise(function(resolve, reject) {
        setTimeout(function() {
            console.log(‘a‘)
            resolve(‘a‘)
        }, 1000)
    })
}

var b = function(data) {
    return new Promise(function(resolve, reject) {
        console.log(‘b‘)
        resolve(data +‘b‘)
    })
}

var c = function(data) {
    return new Promise(function(resolve, reject) {
        setTimeout(function() {
            console.log(‘c‘)
            resolve(data +‘c‘)
        }, 500)
    })
}

// 组织函数队列
function reduce(arr) {
    var sequence = Promise.resolve()

    arr.forEach(function(item) {
        sequence = sequence.then(item)
    })

    return sequence
}

// 顺序执行函数队列
reduce([a, b, c])
.then(function(data) {
    console.log(data)// abc
})
.catch(function(e) {
    console.log(e)
})

  

以上是关于Promise 异步函数顺序执行的主要内容,如果未能解决你的问题,请参考以下文章

详解如何构建Promise队列实现异步函数顺序执行

promise使用

es6 promise

彻底学会promise使用

javaScript-promise

前端面试题之手写promise