7

提案された 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"] }
4

1 に答える 1

10

はい、コールバックを使用してのみアクセスできます。

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);
})

promise の結果に同期的にアクセスする方法はありません。

于 2016-02-11T11:22:42.903 に答える