浏览器扩展与网页交流

需求分析

  • 在 Popup 中展示自定义界面(无需嵌入网页)。
  • 在 Content Script 中执行 DOM 操作(相当于打开F12运行脚本)。
  • 两者通过 Chrome API 通信,Popup 只负责交互和显示最终结果。

通信方式

有两种通信方式,一种是有 Popup 发起通信,一种是由 Content Script 发起通信,推荐使用前者。因为这和实际操作需求相符。

此外,通信方式也有两种,一种是短连接(单次通信),一种是长连接(持续通信),推荐使用后者。

Popup 核心代码如下:

js 复制代码
// 建立通信
const [tab] = await chrome.tabs.query({ active: true, currentWindow: true })
const port = chrome.tabs.connect( tab.id, { name: "linhieng" } )
// 监听消息
port.onMessage.addListener(function (msg) {
	console.log(msg)
})

Content Script 核心代码如下:

js 复制代码
// 监听通道
chrome.runtime.onConnect.addListener(function (port) {
    // 发送消息
    port.postMessage({ msg: `已建立通道连接,通道名为${port.name}` })
    // 获取消息
    port.onMessage.addListener(function (msg) {
        console.log(msg)
    })
})

由 Content Script 中发起通信

Content Script 核心代码如下:

js 复制代码
// 发起通信
const port = chrome.runtime.connect({ name: "linhieng" })
// 发送消息
port.postMessage({ title: document.title })
// 监听消息
port.onMessage.addListener(function (msg) {
    console.log(msg);
})

Popup 核心代码如下(接收通信后,Popup 和 Content Script 代码都是一样的):

js 复制代码
// 监听通道
chrome.runtime.onConnect.addListener(function (port) {
    // 发送消息
    port.postMessage({ msg: `已建立通道连接,通道名为${port.name}` })
    // 获取消息
    port.onMessage.addListener(function (msg) {
        console.log(msg)
    })
})

注意事项

更多细节自行 AI。

注意权限要求:

  • 需要在 manifest.json 中声明 "tabs" 权限。
  • Content Script 需提前注入(通过 manifest.json)。
相关推荐
天人合一peng16 分钟前
Unity中button 和toggle监听事件函数有无参数
前端·unity·游戏引擎
方也_arkling1 小时前
别名路径联想提示。@/统一文件路径的配置
前端·javascript
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于web教师继续教育系统的设计与实现为例,包含答辩的问题和答案
前端
web打印社区1 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
RFCEO2 小时前
前端编程 课程十三、:CSS核心基础1:CSS选择器
前端·css·css基础选择器详细教程·css类选择器使用方法·css类选择器命名规范·css后代选择器·精准选中嵌套元素
Amumu121382 小时前
Vuex介绍
前端·javascript·vue.js
We་ct2 小时前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_949480063 小时前
【无标题】
开发语言·前端·javascript
css趣多多3 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会3 小时前
Web学习之用户认证
前端·学习