第七部分 — 存储 chrome.storage(本地/同步/会话)+ 配额

15.1 目的

服务工作者(SW)可能在空闲时被关闭。 持久化状态必须存于全局变量之外。

chrome.storage 是默认的持久化存储。

15.2 使用场景 / 应避免使用场景

使用场景: 设置、小型状态、标志、缓存元数据。

应避免使用场景: 大型二进制对象(请使用 IndexedDB 或外部存储)。

15.3 最小示例

权限:

  • storage

服务工作者(SW): CODE_BLOCK_64

15.4 本地 vs 同步 vs 会话

  • local: 最大/最快,每个设备独立

  • sync: 用户同步的,配额和写入速率受限

  • session: 在扩展加载期间内存中(重启软件保护程序后保留;在扩展重新加载/更新/禁用或浏览器重启时清除)

最小示例

一个最小的 MV3 安全异步消息处理程序(适合作为模板):

javascript 复制代码
chrome.runtime.onMessage.addListener((msg, sender, sendResponse) => {
  (async () => {
    if (msg?.type !== "PING") return;
    sendResponse({ ok: true });
  })().catch((err) => sendResponse({ ok: false, error: String(err) }));
  return true; // keep channel open for async
});

15.5 常见问题

  • 将 sync 视作数据库(配额错误和写入速率限制)

  • 忘记在 .get({defaults}) 中设置默认值

  • 认为"体积小"而忽略检查文档中的配额(每个键的项数和总字节数会因区域不同而异)

  • 写入过于频繁(采用防抖技术 + 批量写入;特别是在 sync 情况下)

  • 假设 storage.session 对内容脚本默认可用 (它并不总是可用;如果必须使用,请调用 setAccessLevel())

15.6 检查清单

  • \] 选择合适的存储区域(本地/同步/会话)

  • \] 处理配额错误(尤其是同步情况)

  • storage: chrome.storage

相关推荐
Mintopia2 小时前
CSS 你不知道的颜色用法:从现代语法到真实落地的配色策略
前端·css
undeflined2 小时前
EnvManage - 多环境开发代理管理工具
前端·javascript·node.js
三小河2 小时前
从零实现ollama本地大模型可视化+内网穿透
前端·javascript·面试
Mintopia2 小时前
高效简练的 CSS 架构:用最少规则支撑最大规模
前端·css
Cg136269159742 小时前
JS-对象-array数组
开发语言·前端·javascript
weixin456227192 小时前
省市区镇村五级联动
前端·javascript·chrome
窝子面2 小时前
二十三、第三方登录
前端·javascript·html
好运yoo2 小时前
在package.json中scripts这个配置的命令是什么意思
前端·webpack·json·vite·wepack
C澒2 小时前
前端跨业务线代码复用标准化体系构建与实践
前端·架构