【问题标题】:Getting value from returned promise from async function从异步函数返回的承诺中获取价值
【发布时间】:2016-05-22 03:14:06
【问题描述】:

我已经习惯了建议的 async/await 语法,但存在一些不直观的行为。在“异步”函数中,我可以 console.log 正确的字符串。但是,当我尝试返回该字符串时,它会返回一个承诺。

检查这个条目:async/await implicitly returns promise?,很明显任何“异步函数()”都会返回一个承诺,而不是一个值。没关系。但是你如何获得价值呢?如果唯一的答案是“回调”,那很好 - 但我希望可能会有更优雅的东西。

// src 
// ==========================================

require("babel-polyfill");
var bcrypt = require('bcrypt');

var saltAndHash = function(password){
  var hash;
  return new Promise(function(resolve, reject){
    bcrypt.genSalt(10, function(err, salt) {
      bcrypt.hash(password, salt, function(err, hash) {
          resolve(hash);
      });
    });
  })
}

var makeHash = async function(password){
  var hash = await saltAndHash(password);
  console.log("inside makeHash", hash); 
  return(hash); 
}

// from test suite
// ==========================================

describe('Bcrypt Hashing', function(){

  it('should generate a hash', function(){
    var hash = makeHash('password');
    console.log("inside test: ", hash); 
    should.exist(hash);
  })

})

// output to console:
// ==========================================

  inside test:  Promise {
  _d: 
   { p: [Circular],
     c: [],
     a: undefined,
     s: 0,
     d: false,
     v: undefined,
     h: false,
     n: false } }

  inside MakeHash $2a$10$oUVFL1geSONpzdTCoW.25uaI/LCnFqeOTqshAaAxSHV5i0ubcHfV6

  // etc 
  // ==========================================
  // .babelrc
    {  "presets": ["es2015", "stage-0", "react"] }

【问题讨论】:

  • @JoachimIsaksson:只有 inside async 函数。

标签: javascript async-await ecmascript-next


【解决方案1】:

是的,您只能使用回调来访问它:

makeHash('password').then(hash => console.log(hash));

当然,您也可以创建另一个等待它的异步函数:

it('should generate a hash', async function(){
  var hash = await makeHash('password');
  console.log("inside test: ", hash); 
  should.exist(hash);
})

无法同步访问承诺的结果。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2022-01-26
    • 1970-01-01
    • 1970-01-01
    • 2018-12-22
    相关资源
    最近更新 更多