使用 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 的执行程序中的某个地方,但这看起来很混乱,而且我不确定它是在何时运行该函数时定义的——它总是在构造时立即运行吗?
谢谢。