Используя ES6 promises, как мне создать обещание без определения логики его решения? Вот базовый пример (некоторые 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 :(
}
Это легко сделать с другими библиотеками обещаний. Например, 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);
}
Единственный способ, с помощью которого я могу это сделать, - сохранить функцию разрешения где-то внутри исполнителя обещаний, но это кажется беспорядочным, и я не уверен, что он определен, когда именно эта функция запускается - всегда ли она выполняется немедленно по строительству?
Спасибо.