【chrome扩展开发】消息通讯之onMessage消息监听

前言

chrome.runtime.onMessage.addListener 是 Chrome 扩展程序中用于监听其他模块发送的消息并做出响应的 API

当从扩展进程 (by runtime.sendMessage) 或内容脚本 (by tabs.sendMessage)发送消息时触发

语法

javascript 复制代码
chrome.runtime.onMessage.addListener(
  callback: function,
)

callback参数如下:

(message: any, sender: MessageSender, sendResponse: function) => boolean | undefined

参数 类型 说明
request Any 包含发送者的信息和请求的内容
sender MessageSender 包含发送者的详细信息
sendResponse Function 是一个可以用来向发送者发送响应的函数

基本示例

javascript 复制代码
chrome.runtime.onMessage.addListener(
  function(request, sender, sendResponse) {
    console.log(sender.id + " 发送了请求:" + request.data);
    // 你可以在这里处理接收到的消息
    // 如果需要,你可以通过 sendResponse 函数发送响应给发送者
    // sendResponse({data: "回复消息"});
  }
);

在这个例子中,我们监听来自任何发送者的消息;

每当有消息发送时,监听函数(callback)就会被调用;

注意

出于安全考虑,发送的消息和响应必须在相同的扩展程序内传递不能跨越扩展程序
onMessage方法需要在background脚本中注册

封装

示例

javascript 复制代码
const listenerList = {
	token: function({ request, response }){
		// code...
	},
	/**
	 * 创建与项目的共享变量数据
	 */
	createPluginVariable: function({ request, response }){
		let name = SystemEnum.APP_PLUGIN_KEY;
	    let value = '1';
	    let _cf = {url: SysConfig.APP_URL, name}
	    chrome.cookies.remove(_cf,function (res) {
	      _cf.domain = SysConfig.APP_DOMAIN;
	      _cf.value = value;
	      _cf.expirationDate = new Date().setDate(new Date().getDate() + 7);
	      chrome.cookies.set(_cf, function (res) {
	        response({name, value, config: request, res})
	      });
	    });
	}
};

const message = new MessageListener();
for (let messageKey in listenerList){
  message.addListener(messageKey, listenerList[messageKey]);
}
message.start();

// content script脚本中发送消息
// chrome.runtime.sendMessage({contentRequest:'createPluginVariable'}, ()=>{})

实现

javascript 复制代码
class MessageListener {
  /**
   * @var chrome.runtime.onMessage|null
   */
  _message
  /**
   * @var Object
   */
  _listener

  constructor() {
    this._listener = {}
    this._message = chrome.runtime.onMessage || null
    return {
      addListener: (messageKey, request) => this.addListener(messageKey, request),
      start: () => this.start(),
    }
  }

  addListener(messageKey, request) {
    this._listener[messageKey] = request
  }

  start() {
    if (!this._message) return
    let that = this
    that._message.addListener(function (request, sender, response) {
      return (
        chrome.tabs.query({ currentWindow: !0, active: !0 }, function () {
          if (!!that._listener[request.contentRequest]) {
            that._listener[request.contentRequest]({
              request,
              response,
            })
          }
        }),
        !0
      )
    })
  }
}

Chrome Developers官方接口文档:

相关推荐
萌萌哒草头将军3 分钟前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
AALoveTouch1 小时前
大麦APP抢票揭秘
javascript
持久的棒棒君2 小时前
启动electron桌面项目控制台输出中文时乱码解决
前端·javascript·electron
小离a_a2 小时前
使用原生css实现word目录样式,标题后面的...动态长度并始终在标题后方(生成点线)
前端·css
郭优秀的笔记3 小时前
抽奖程序web程序
前端·css·css3
布兰妮甜3 小时前
CSS Houdini 与 React 19 调度器:打造极致流畅的网页体验
前端·css·react.js·houdini
小小愿望3 小时前
ECharts 实战技巧:揭秘 X 轴末项标签 “莫名加粗” 之谜及破解之道
前端·echarts
小小愿望4 小时前
移动端浏览器中设置 100vh 却出现滚动条?
前端·javascript·css
fail_to_code4 小时前
请不要再只会回答宏任务和微任务了
前端
摸着石头过河的石头4 小时前
taro3.x-4.x路由拦截如何破?
前端·taro