通过Promises排队异步操作

时间:2015-09-17 22:21:02

标签: javascript ecmascript-6 es6-promise

我发现有一篇文章解释了如何排队异步操作,但它相当模糊,因为它说如果你从then函数返回一个“类似promise”的对象,它将会成为下一个then等待它完成。我不知道“承诺之类”是什么意思,所以我对此进行了一次尝试(见下面的代码),但它确实有效,但我不确定这是否是正确的方法。

let promise = new Promise(function (resolve, reject) {
  someAsyncOperation(function () {
    resolve({done: true});
  });
});

promise.then(function (val) {
  return new Promise(function (resolve, reject) {
    anotherAsyncOperation(function () {
      resolve({doneAgain: true});
    });
  });
}).then(function (val) {
  // This only occurs after the anotherAsyncOperation is done
});

1 个答案:

答案 0 :(得分:1)

是的,您的代码应该用于创建一个等待anotherAsyncOperation完成的承诺。

let promise = new Promise(function(resolve, reject) {
    console.log('1');
    someAsyncOperation(function() {
        resolve({ done: true });
    });
}).then(function(val) {
    // val == { done: true }
    return new Promise(function(resolve, reject) {
        console.log('2');
        anotherAsyncOperation(function() {
            resolve({ doneAgain: true });
        });
    });
}).then(function(val) {
    // val == { doneAgain: true }
    console.log('3');
});

@Amit的意思是你可以创造" Promisified"回调式异步操作的版本。

function promisify( operation ) {
    return function( ) {
        return new Promise(function(resolve, reject) {
            operation(function( err, val ) {
                if (err) reject(err);
                else resolve(val);
            });
        });
    };
}

var someAsyncOp = promisify( someAsyncOperation );
var anotherAsyncOp = promisify( anotherAsyncOperation );

console.log('1');
var promise = someAsyncOp()
    .then(function( val ) {
        console.log('2');
        return anotherAsyncOp();
    })
    .then(function( val ) {
        console.log('3');
    });

请注意,有一些promise库的promisify函数比我展示的更好File.rename("tempFile.csv", @data_file) 。请使用其中之一。