Chrome 浏览器插件 升级到V3 版本

背景

Chrome插件的Manifest V3版本是Chrome团队对插件系统进行的一次重大升级。这次升级的主要目标是提高插件的性能、隐私和安全性。V3版本引入了很多新的API和功能,同时也对一些旧的API进行了限制或者移除,以减少插件对用户隐私的潜在威胁和提高浏览器的性能。

升级到V3版本的主要好处包括:

更好的性能:V3版本的插件运行在更少的背景页面上,这可以大大减少插件对系统资源的占用。 更高的安全性:V3版本引入了新的权限系统,可以更精细地控制插件的权限,减少插件被恶意利用的风险。 更强的隐私保护:V3版本限制了一些可能侵犯用户隐私的API,比如webRequest API。

升级步骤

1. 更新manifest.json

首先,你需要将manifest.json文件中的"manifest_version"字段的值改为3。

json 复制代码
{
  "manifest_version": 3,
  ...
}

2. 替换背景脚本

在V3版本中,长期运行的背景页面被替换为了服务工作线程。你需要将background字段中的"persistent"设置为false,并将"scripts"改为"service_worker"。

json 复制代码
{
  ...
  "background": {
    "service_worker": "background.js",
    "persistent": false
  },
  ...
}

3. 更新权限

V3版本引入了新的权限系统,你需要将"permissions"字段改为"host_permissions",并将需要的API权限添加到"permissions"字段中。

json 复制代码
{
  ...
  "permissions": ["alarms", "storage"],
  "host_permissions": ["<all_urls>"],
  ...
}

4. 替换webRequest API

V3版本限制了webRequest API的使用,你需要将其替换为declarativeNetRequest API。

php 复制代码
chrome.declarativeNetRequest.updateDynamicRules({
  removeRuleIds: [1],
  addRules: [{
    id: 1,
    priority: 1,
    action: { type: 'block' },
    condition: { urlFilter: '||example.com^', resourceTypes: ['main_frame'] }
  }]
});

5. 测试和调试

最后,你需要在chrome://extensions页面中加载你的插件,并使用开发者工具进行测试和调试。

结语

升级到Manifest V3版本需要对插件进行一些重大的修改,但这些修改将使你的插件更加高效、安全和隐私友好。希望这篇教程能帮助你顺利完成升级。

相关推荐
JIngJaneIL8 分钟前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼13 分钟前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
一位搞嵌入式的 genius17 分钟前
前端实战开发(三):Vue+Pinia中三大核心问题解决方案!!!
前端·javascript·vue.js·前端实战
塞纳河畔的歌17 分钟前
保姆级教程 | 麒麟系统安装Edge浏览器
前端·edge
多睡觉觉19 分钟前
数据字典:从"猜谜游戏"到"优雅编程"的奇幻之旅
前端
嗝屁小孩纸22 分钟前
开发集成热门小游戏(vue+js)
前端·javascript·vue.js
赛博切图仔27 分钟前
深入理解 package.json:前端项目的 “身份证“
前端·javascript
UIUV30 分钟前
JavaScript 学习笔记:深入理解 map() 方法与面向对象特性
前端·javascript·代码规范
太平洋月光40 分钟前
MJML邮件如何随宽度变化动态切换有几列📮
前端·css
AAA不会前端开发42 分钟前
TypeScript核心类型系统完全指南
前端·typescript