概述BFCache 能快速恢复页面。本文在恢复时校验并更新状态,避免展示过期数据。恢复检测与状态更新async function loadState(key) { const db = await new Promise((res, rej) => { const r = indexedDB.open('state', 1); r.onupgradeneeded = () => { const db = r.result; if (!db.objectStoreNames.contains('s')) db.createObjectStore('s'); }; r.onsuccess = () => res(r.result); r.onerror = () => rej(r.error); }); const tx = db.transaction('s','readonly'); const req = tx.objectStore('s').get(key); const v = await new Promise((res, rej) => { req.onsuccess = () => res(req.result); req.onerror = () => rej(req.error); }); db.close(); return v; } addEventListener('pageshow', async e => { if (e.persisted) { const st = await loadState('app'); if (st) { // 使用最新状态刷新视图 } } });

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论
立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部
1.906436s