【发布时间】: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