Q promise の仕組みを誤解していると思います。次の約束が始まる前に最初の約束を解決したいのですが、それは実現していません。これが私のコードです:
var Q = require('q');
function doWork(taskName) {
var deferred = Q.defer();
console.log('starting', taskName);
setTimeout(function() {
console.log('done with', taskName);
deferred.resolve();
});
return deferred.promise;
}
doWork('task one')
.then(doWork('task two'))
.then(function() { console.log('all done'); });
このコードは以下を生成します。
$ node test.js
starting task one
starting task two
done with task one
done with task two
all done
私はそれが生成することを願っています:
$ node test.js
starting task one
done with task one
starting task two
done with task two
all done
私は何を間違っていますか?