第一部分 — 基础知识 MV3 心智模型(实际发生了什么变化)

1.1 目的

MV3 改变了扩展程序保持存活和获取特权访问的方式。 如果您像 MV2 那样设计(持久后台 + 隐式状态),将更容易出现不稳定的行为。

实际上,MV3 关于约束:

  • 后台是 事件驱动 的(通过扩展服务工作者(SW)实现;可能在空闲时被关闭)

  • 权限必须是 明确和可解释的

  • 请求修改向 声明性规则 (DNR)转移

1.2 使用时机 / 避免使用时机

使用本章节时:

  • 你在迁移 MV2 代码,且遇到"随机停止工作"的问题

  • 你正在设计一个新的 MV3 扩展,并希望获得正确的架构

避免使用时: 你只需要一个单独的 API 片段。 跳转至 API 章节。

1.3 一页面内的 MV3 运行时模型

用 上下文 思考(每个上下文有不同的能力):

  • 服务工作者(SW)

  • 事件处理器 + 协调

  • 可能被停止/重启

  • 没有 DOM (没有直接的页面访问)

  • 扩展页(UI)

  • 弹出窗口、选项页面、侧边栏面板

  • DOM 可用

  • 生命周期取决于表面积(弹出窗口关闭得很快)

  • 内容脚本

  • 在网页中运行(隔离的世界)

  • 适合 DOM 操作

  • 对某些受特权保护的 API 访问有限

  • 离屏文档(可选)

  • 扩展自有的隐藏页面,用于进行类似 DOM 的任务

  • 服务工作者(SW)协调;离屏文档完成工作

1.4 预防 MV3 80% 痛苦的设计规则

规则 A:应假设 SW 在空闲时可能被关闭(且可能无通知)。

  • 持久化状态 → chrome.storage

  • 动态计算 → 每次请求重新加载状态

规则 B:默认情况下 UI 不应直接与标签页进行通信。

  • UI → SW(路由、权限检查)

  • SW → 内容脚本(标签页相关工作) 规则 C:保持工作范围明确且可恢复。

  • 短暂处理程序

  • 幂等操作

  • 长任务的检查点

1.5 最小化架构(复制/粘贴图)

复制代码
[Popup / Options / Side panel]
        |
        | runtime.sendMessage({action, requestId})
        v
[Service worker (SW)]
  - validates permissions + sender
  - loads state from storage
  - picks target tab
        |
        | tabs.sendMessage(tabId, ...)
        v
[Content script]
  - DOM work
  - returns result

最小示例

一个最小的 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
});

1.6 常见问题

  • 将SW当作长时间运行的进程来对待

  • 只将"重要的真理"存储在全局变量中

  • 使用tabs.sendMessage而不确保存在内容脚本

  • 请求过多权限(延迟审核 + 用户不信任)

1.7 检查表

相关推荐
刘~浪地球21 小时前
Redis 从入门到精通(七):集合操作详解
数据库·chrome·redis
秋夜无霜1 天前
一场因chrome浏览器调试模式network中设置了offline模式导致的页面调试就会导致数据无法正常加载
chrome
刘~浪地球2 天前
Redis 从入门到精通(六):列表操作详解
数据库·chrome·redis
入瘾2 天前
etcd 显示连接失败
数据库·chrome·etcd
Z_Wonderful3 天前
在 Next.js 中,使用 [id] 或 public 作为文件夹或文件名是两种完全不同的概念,分别对应 动态路由 和 静态资源托管
javascript·网络·chrome
油丶酸萝卜别吃3 天前
本地调试跨域问题:关闭 Chrome 同源策略的技巧
前端·chrome
x-cmd3 天前
[x-cmd] 专为 AI Agent 设计的无头浏览器,比 Chrome 速度快 9 倍且少用 16 倍内存 | Lightpanda
前端·chrome·ai·自动化·agent·浏览器·x-cmd
PyHaVolask3 天前
Linux实用工具与技巧
linux·运维·chrome
FreeBuf_3 天前
Chrome 0Day漏洞遭野外利用
前端·chrome
a里啊里啊4 天前
测试开发面试题
开发语言·chrome·python·xpath