chrome扩展,“manifest_version“: 3, chrome 扩展图标点击事件

在 Chrome 扩展中,从 Manifest V3 开始,后台脚本(background scripts)被服务工作线程(service workers)所取代。这改变了扩展图标点击事件(通常称为浏览器操作或者页面操作)的处理方式。在 Manifest V3 中,您需要使用 chrome.action.onClicked 监听器来处理扩展图标的点击事件。

下面是一个如何设置扩展图标点击事件处理器的示例:

  1. manifest.json 文件中,确保已经声明了 action 字段:
json 复制代码
{
  "manifest_version": 3,
  "name": "您的扩展名称",
  "version": "1.0",
  "action": {
    "default_popup": "popup.html", // 可选的弹出页面
    "default_icon": {
      "16": "images/icon16.png",
      "48": "images/icon48.png",
      "128": "images/icon128.png"
    }
  },
  "background": {
    "service_worker": "background.js"
  },
  "permissions": [
    "activeTab"
    // 其他可能需要的权限
  ],
  // 其他可能需要的字段
}
  1. 在您的服务工作线程脚本(通常是 background.js)中添加点击事件监听器:
javascript 复制代码
// background.js
chrome.action.onClicked.addListener((tab) => {
  // 当扩展图标被点击时,执行下面的代码
  console.log("扩展图标被点击了!");

  // 可以在这里执行各种操作,例如打开新的标签页,注入脚本等
  // 例如:注入content script到当前标签页
  /* chrome.scripting.executeScript({
    target: { tabId: tab.id },
    files: ['content.js']
  }); */

  // 打开一个新的标签页
  /* chrome.tabs.create({ url: 'https://example.com' }); */
});

请注意,如果您定义了默认的弹出页面(default_popup),当用户点击扩展图标时,将会显示这个弹出页面,并且不会触发 chrome.action.onClicked 监听器。如果您想要编写自己的点击处理逻辑,请不要在 manifest.jsonaction 字段中设置 default_popup,或者将其设置为空字符串。

人工智能学习网站:
https://chat.xutongbao.top

相关推荐
yingyima11 分钟前
Azure Functions 定时触发器配置:Cron vs. TimerTrigger,谁主沉浮?
前端
TeamDev15 分钟前
JxBrowser 9.1.1 版本发布啦!
java·前端·chromium·混合应用·jxbrowser·嵌入式浏览器·浏览器控件
爱勇宝17 分钟前
如何评估 AI 大模型的商业价值?
前端·后端·程序员
蜡台1 小时前
UniApp WebView 组件宽高设置与动态适配全方案
前端·javascript·uniapp·webview·iframe
半个烧饼不加肉1 小时前
JS 底层探究-- 调用栈(Call Stack)
开发语言·前端·javascript
子午1 小时前
基于DeepSeek的智能校园教务管理系统~Web管理系统+Vue3+Python+DeepSeek智能问答
前端
change_fate1 小时前
ERR_PNPM_WORKSPACE_PKG_NOT_FOUND In ...
java·服务器·前端
超人不会飞_Jay2 小时前
26.6.3Vue笔记
前端·vue.js·笔记
御坂100272 小时前
Vue - @change应用实现下拉框联动功能
前端·javascript·vue.js
小雨下雨的雨2 小时前
基于 Electron 运行时的鸿蒙PC桌面应用-安全可靠的随机密码生成工具
前端·javascript·华为·electron·前端框架·鸿蒙