ES6 promise を使用して、それを解決するためのロジックを定義せずに promise を作成するにはどうすればよいですか? 基本的な例を次に示します (一部の TypeScript)。
var promises = {};
function waitFor(key: string): Promise<any> {
if (key in promises) {
return promises[key];
}
var promise = new Promise(resolve => {
// But I don't want to try resolving anything here :(
});
promises[key] = promise;
return promise;
}
function resolveWith(key: string, value: any): void {
promises[key].resolve(value); // Not valid :(
}
他の promise ライブラリで簡単に実行できます。JQuery の例:
var deferreds = {};
function waitFor(key: string): Promise<any> {
if (key in promises) {
return deferreds[key].promise();
}
var def = $.Deferred();
deferreds[key] = def;
return def.promise();
}
function resolveWith(key: string, value: any): void {
deferreds[key].resolve(value);
}
これを行う唯一の方法は、resolve 関数を promise のエグゼキューター内のどこかに保存することですが、それは面倒に思えます。この関数が正確に実行されたときに定義されているかどうかはわかりません-常に構築時にすぐに実行されますか?
ありがとう。