chrome插件 manifest 2 to 3

简介: chrome插件 manifest 2 to 3

改版的原因:

相当蛋疼 下面是 基于现有插件 需要做的一些改变的清单

1.background 替换成service worker:
需要注意的是:不使用时终止,需要时重新启动(类似于事件页面)。
无权访问 DOM。(service worker独立于页面,无法使用window对象)
2.v3 废弃了一些方法:
chrome.extension.sendRequest()
chrome.extension.onRequest
chrome.extension.onRequestExternal
chrome.extension.lastError
chrome.extension.getURL()
chrome.extension.getExtensionTabs()
chrome.tabs.Tab.selected
chrome.tabs.sendRequest()
chrome.tabs.getSelected()
chrome.tabs.getAllInWindow()
chrome.tabs.onSelectionChanged
chrome.tabs.onActiveChanged
chrome.tabs.onHighlightChanged
还有一些未在文档中明确声明的已失效的 API

chrome.extension.sendMessage()
chrome.extension.connect()
chrome.extension.onConnect
chrome.extension.onMessage
影响到我们的API(主要是contentScript与background通讯的部分):

chrome.extension.sendMessage()
chrome.extension.connect()
chrome.extension.onConnect
chrome.extension.onMessage
替换的方法:

chrome.runtime.sendMessage //发消息
chrome.runtime.onMessage.addListener // 接受消息
具体的代码使用:

发送消息以及接受回调返回的消息:

//// content.js ////
// 1. Send the background a message requesting the user's data
chrome.runtime.sendMessage('get-user-data', (response) => {
// 3. Got an asynchronous response with the data from the background
console.log('received user data', response);
initializeUI(response);
});
复制代码
接受消息,并返回消息

//// background.js ////

// Example of a simple user data object
const user = {
username: 'demo-user'
};

chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
// 2. A page requested user data, respond with a copy of user
if (message === 'get-user-data') {

sendResponse(user);

}
});
复制代码
参考文档:

https://juejin.cn/post/7000363901221093412

https://juejin.cn/post/7021072232461893639

3.比较蛋疼的v3的严格模式 禁止了之前的vue实例化写法:
具体的vue实例化写法可以参考之前的一篇文章:h5引用vue

先看看报错:

unsafe-eval:

‘unsafe-inline’和‘unsafe-eval’表达式重新启用内联JavaScript和动态代码执行,这些默认情况下都是被CSP禁用的。理想情况下,通常不会希望在策略里保留这些表达式,但没有它们大多数现有的应用都会被阻断。
这个暂时还没想到比较好的解决方法,后续会更新

问题描述:https://blog.csdn.net/qq_35606400/article/details/114986532

尝试解决方案1:

//Manifest v2
"content_security_policy": "script-src 'self' 'unsafe-eval'; object-src 'self'"

//Manifest v3
"content_security_policy": {
"extension_pages": "script-src 'self' 'unsafe-eval'; object-src 'self'",
}
复制代码
添加unsafe-eval标实,但是插件会给我们抛错:

'content_security_policy.extension_pages': Insecure CSP value "'unsafe-eval'" in directive 'script-src'.

'content_security_policy.extension_pages':指令'script-src'中的不安全CSP值“'unsafe-eval'”。

这就很蛋疼,现在问题卡在这里,后续有进展再更新

好了 找到官方解释了,不支持了 完犊子了

4.尝试解决方法 通过webpack构建
参考文档:https://www.it1352.com/2289545.html

https://github.com/StarkShang/vite-plugin-chrome-extension

https://github.com/ALiangLiang/vue-webpack-chrome-extension-template

更新相关的构建文章:vite-plugin-chrome-extension(Vue版本)

作者: Bill 本文地址: http://biaoblog.cn/info?id=1640156600130

版权声明: 本文为原创文章,版权归 biaoblog 个人博客 所有,欢迎分享本文,转载请保留出处,谢谢!

相关文章
|
1月前
|
Web App开发 JSON JavaScript
vue学习:chrome 中 vuetools 开发插件 的下载、安装
这篇文章介绍了如何在Chrome浏览器中下载、安装并测试Vue.js开发插件——vue-devtools。
265 0
vue学习:chrome 中 vuetools 开发插件 的下载、安装
|
3月前
|
Web App开发 JSON 前端开发
30个Chrome 灵魂插件!
30个Chrome 灵魂插件!
|
3月前
|
Web App开发 前端开发 JavaScript
手摸手教你,从0到1开发一个Chrome浏览器插件
开发 Chrome 插件既有趣又具成就感。本教程将引导你从零开始,逐步创建一个简单的 Chrome 插件。首先了解 Chrome 插件是可增强浏览器功能的小程序。以一个基础示例开始,你将学习如何设置开发环境,包括安装 Chrome 和准备文本编辑器,并掌握 HTML、CSS 和 JavaScript 的基础知识。接着,我们将构建插件的基本结构,涉及 `manifest.json` 配置文件、`background.js` 后台脚本、`popup.html` 用户界面以及 `style.css` 样式表。
307 8
|
3月前
|
Web App开发
Chrome 护眼模式 - 黑暗模式 - 夜眼(Night Eye) 插件
Chrome 护眼模式 - 黑暗模式 - 夜眼(Night Eye) 插件
137 0
Chrome 护眼模式 - 黑暗模式 - 夜眼(Night Eye) 插件
|
4月前
|
Web App开发 JavaScript 前端开发
Chrome插件实现问题之最新的 Chrome 浏览器架构有什么新的改变吗
Chrome插件实现问题之最新的 Chrome 浏览器架构有什么新的改变吗
|
4月前
|
JavaScript 前端开发 Web App开发
Chrome插件实现问题之单进程浏览器的不稳定主要体现在什么地方
Chrome插件实现问题之单进程浏览器的不稳定主要体现在什么地方
|
4月前
|
Web App开发 数据可视化 前端开发
Chrome插件实现问题之content-scripts能访问哪些Chrome API
Chrome插件实现问题之content-scripts能访问哪些Chrome API
|
4月前
|
Web App开发 前端开发 JavaScript
Chrome插件实现问题之用户在浏览器中输入URL后,浏览器进程会进行什么操作
Chrome插件实现问题之用户在浏览器中输入URL后,浏览器进程会进行什么操作
|
4月前
|
Web App开发 JavaScript 前端开发
Chrome插件实现问题之在Manifest V2中,设置插件的图标要如何解决
Chrome插件实现问题之在Manifest V2中,设置插件的图标要如何解决
|
4月前
|
缓存 安全 Web App开发
Chrome插件实现问题之网络进程接收到URL请求后会如何解决
Chrome插件实现问题之网络进程接收到URL请求后会如何解决