【发布时间】:2018-05-01 10:48:10
【问题描述】:
我要对后端进行 x 次调用。其中一些指向相同的 URL。我正在缓存结果。但我的问题是,如果我立即使用相同的 URL 调用 loadCached 两次(或多次),它实际上也会调用 fetch 两次,因为在第一次 fetch 解决之前缓存没有 url。因此,缓存仅在一次提取成功完成(=已解决)时才起作用。如何改进代码以等待解决第一次提取以避免重复查询?
function loadCached(url) {
let cache = loadCached.cache || (loadCached.cache = new Map());
if (cache.has(url)) {
return Promise.resolve(cache.get(url)); // (*)
}
return fetch(url)
.then(response => response.text())
.then(text => {
cache[url] = text;
return text;
});
}
我正在使用 promise.all() 来等待 loadCached 解决。
【问题讨论】:
-
你需要缓存 promise 而不是结果。
标签: javascript node.js caching promise fetch-api