提案された async/await 構文に慣れてきましたが、直感的でない動作がいくつかあります。「async」関数内で、正しい文字列を console.log に記録できます。ただし、その文字列を返そうとすると、代わりに約束が返されます。
このエントリをチェックする: async/await は暗黙的に promise を返しますか? 、「async function()」が値ではなくプロミスを返すことは明らかです。それはいいです。しかし、どうやって値にアクセスするのでしょうか? 唯一の答えが「コールバック」である場合は、それで問題ありませんが、もっとエレガントなものがあることを期待していました。
// 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"] }