静默归并通过闭包缓存Promise实现请求合并:用参数序列化为key,命中则复用已settled的Promise,未命中才发起新请求;所有调用共享最终结果,不重复请求、不报错、不中断。
直接用闭包缓存 Promise 实例,让相同参数的后续调用复用同一个 Promise,就能自然实现“静默归并”——既不重复发起请求,也不报错或中断,所有调用共享最终结果。
Promise 一旦进入 fulfilled 或 rejected 状态,就再也不会改变。闭包则能长期持有对这个已创建 Promise 的引用,后续调用无需新建 Promise,直接返回它即可。
关键点:
以下是一个通用封装函数:
function createCachedFetcher(fetcher) {
const cache = new Map();
return function(...args) {
const key = JSON.stringify(args);
if (cache.has(key)) {
return cache.get(key);
}
const promise = fetcher(...args).finally(() => cache.delete(key));
cache.set(key, promise);
return promise;
};
}
使用方式:
const fetchUser = createCachedFetcher((id) => fetch(`/api/user/${id}`).then(r => r.json()));
fetchUser(123).then(data => console.log(data)); // 发起请求
fetchUser(123).then(data => console.log(data)); // 复用上一个 Promise,无新请求
实际项目中需关注几个细节:
静默归并不是延迟执行,也不是丢弃调用,而是结果共享:
它特别适合用户快速点击、表单多次提交、自动补全等场景——体验流畅,后端压力小,代码逻辑干净。