使用从内部函数返回的异步数据对外部函数返回promise

Return a promise on an external function with async data returned from an inner function

本文关键字:返回 数据 对外部 函数 promise 异步 内部函数      更新时间:2023-09-26

我正在设计一个用户API,API的部分代码如下:

module.exports = {
  findByEmail: (email) => {
    db.collection('Users').findOne(email: email), (err, result) => {
      assert.equal(err, null);
      return new Promise(resolve) => {
        resolve(result);
      }
    }
  }
}

我的意图是让findByEmail返回一个promise,以便可以调用它,例如:

require('./models/User').findByEmail({email: 'user@example.com'})
.then((user) => {
  console.log('User account', user);
});

然而,像上面那样定义我的API并不能实现我想要的,因为内部函数是返回promise的函数,而外部函数(即findByEmail)最终没有返回promise。如何确保外部函数使用内部函数返回的数据返回promise?

当然,让外部函数接受回调是一种选择,但这意味着外部函数不再具有可承诺性。

首先返回promise,然后让promise回调函数完成其余操作。

module.exports = {
  findByEmail: (email) => {
    return new Promise((resolve, reject) => {
      db.collection('Users').findOne(email: email), (err, result) => {
        //   assert.equal(err, null);
        if (err) {
          reject(err);
        }
        resolve(result);
      }
    }
  }
}

这里我调用listings(),在得到响应后,在其中进行jquery ajax调用,我将promise返回到从外部文件调用的函数getlistings(

function Listings(url){
var deferred = new $.Deferred();
$.ajax({
    url: url,
    method: 'GET',
    contentType: 'application/json',
    success: function (response) {
        deferred.resolve(response);
    },
    error: function (response){
        deferred.reject(response);
    }
});
return deferred.promise();  
};
// call from external file
function getListings(){
Listings('/listings.json').then(function(response){
 console.log(response);
});
}