第七部分 — 存储 数据建模与迁移提示

16.1 目的

随着您的扩展程序不断演化,存储的数据也会随之变化。 本节展示了一个轻量级的迁移模式。

16.2 使用场景 / 避免场景

使用场景: 当您需要在版本间安全地更改存储设置而不会破坏现有安装时,请使用此方法。

避免场景: 当您需要一个完整的数据库或复杂的查询(考虑 IndexedDB 或服务器支持的存储)。

16.3 最小化迁移模式

存储一个模式版本:

javascript 复制代码
const KEY = "settings";
const CURRENT = 2;

async function loadSettings() {
  const out = await chrome.storage.local.get({ [KEY]: { version: 0 } });
  let s = out[KEY];

  if (!s || typeof s !== "object") s = { version: 0 };

  // Forward-compat: if a newer version somehow exists, don't smash it.
  if ((s.version ?? 0) > CURRENT) return s;

  while ((s.version ?? 0) < CURRENT) {
    const prev = s.version ?? 0;
    s = migrateOnce(s);
    if ((s.version ?? 0) <= prev) {
      throw new Error("migration did not advance version");
    }
  }

  await chrome.storage.local.set({ [KEY]: s });
  return s;
}

function migrateOnce(s) {
  if (s.version === 0) {
    return { version: 1, enabled: true };
  }
  if (s.version === 1) {
    // example: rename field
    const { enabled } = s;
    return { version: 2, isEnabled: enabled };
  }
  return s;
}

最小示例

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

16.4 雷区

  • 不具备幂等性的单次迁移

  • 没有版本字段的老安装被破坏

16.5 检查清单

  • 存储 version

  • 使迁移幂等

  • 保持迁移小巧且可测试

16.6 参考资料

相关推荐
zfoo-framework8 分钟前
[修改代码使用]codex官方app中使用中转(不需要cc-switch) 1.config.toml 2.sk方式登录
java
天佑木枫12 分钟前
15天Python入门系列 · 序
开发语言·python
逍遥德27 分钟前
MQTT教程详解-05.SpringBoot集成mqtt client 性能分析
java·spring boot·spring·mt
云烟成雨TD32 分钟前
Spring AI 1.x 系列【54】Retry 机制分析
java·人工智能·spring
weixin_5231853235 分钟前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
点燃大海36 分钟前
SpringAI构建智能体
java·spring boot·spring·springai智能体
xier_ran38 分钟前
【infra之路】02_RadixAttention与KV_Cache管理
java·spring boot·spring
黑马师兄1 小时前
RAG混合检索深度解析:让AI真正找到你要的内容
java·人工智能·ai·agent·rag·ai-native
码客日记1 小时前
Spring Boot 配置文件敏感信息加密(Jasypt 企业级完整方案)
java·spring boot·git
宋拾壹1 小时前
同时添加多个类目
android·开发语言·javascript