瀏覽器擴展V3開發系列之 chrome.contextMenus 右鍵菜單的用法和案例

【作者主頁】:小魚神1024

【擅長領域】:JS逆向、小程序逆向、AST還原、驗證碼突防、Python開發、瀏覽器插件開發、React前端開發、NestJS后端開發等等

chrome.contextMenus 允許開發者向瀏覽器的右鍵菜單添加自定義項。

在使用 chrome.contextMenus 之前,必須在 manifest.json 中聲明權限:
image.png

{"manifest_version": 3,"name": "chrome.contextMenus","description": "chrome.contextMenus API 基礎用法","version": "1.0","action": {"default_popup": "popup.html","default_icon": "icons/icon128.png"},"background": {"service_worker": "background.js"},"permissions": ["contextMenus"],"icons": {"16": "icons/icon16.png","48": "icons/icon48.png","128": "icons/icon128.png"}
}

在 manifest.json 聲明 contextMenus 權限。

1、chrome.contextMenus.create

可以通過 chrome.contextMenus.create 進行創建右鍵菜單,如下:
image.png

chrome.runtime.onInstalled.addListener(function () {chrome.contextMenus.create({id: "1",title: "右鍵菜單選擇一",});
});

看看效果吧。
屏幕截圖 2024-04-01 141206.png
chrome.contextMenus.create 有哪些參數可配置呢?

  • id:菜單項的唯一標識符
  • title:菜單名稱
  • type:菜單類型,包括:“normal”(默認) | “checkbox”(多選) | “radio”(單選) | “separator” (分隔符)
  • contexts:菜單項出現的上下文,包括:
"all": 上下文菜單項將在所有可用的上下文中顯示。
"page": 表示上下文菜單項只在常規網頁的空白處(非鏈接、非媒體等)上點擊時顯示。
"frame": 表示上下文菜單項只在網頁中的 iframe 上點擊時顯示。
"selection": 表示上下文菜單項只在用戶選中文本時顯示。
"link": 表示上下文菜單項只在鏈接上點擊時顯示。
"editable": 表示上下文菜單項只在可編輯區域(如文本框)點擊時顯示。
"image": 表示上下文菜單項只在圖像上點擊時顯示。
"video": 表示上下文菜單項只在視頻上點擊時顯示。
"audio": 表示上下文菜單項只在音頻元素上點擊時顯示。
"launcher": (已棄用)原先用于Chrome應用的啟動器上的菜單。
"action": 表示上下文菜單項只在擴展的操作按鈕(地址欄旁的圖標)上點擊時顯示。
  • parentId:父級菜單唯一標識
  • checked:當 type 為多選或單選時,菜單是否被選中
  • enabled:菜單是否被禁用
  • documentUrlPatterns:指定上下文菜單項應該在哪些文檔頁面的 URL 中顯示
  • targetUrlPatterns:匹配觸發上下文菜單項顯示的鏈接的 URL

其中:id、title、parentId、checked、enabled 都是比較容易理解的。就不一一舉例了。

假設我們希望當選中文字右鍵時,菜單按分類展示,比如:一級菜單:水果類;二級菜單:蘋果、梨子、西瓜
可以如下創建菜單:
image.png

chrome.runtime.onInstalled.addListener(function () {// 定義菜單const menuList = [{id: "1",title: "水果類",children: [{ id: "1-1", title: "蘋果", parentId: "1" },{ id: "1-2", title: "梨子", parentId: "1" },{ id: "1-3", title: "西瓜", parentId: "1" },],},];// 創建菜單function createMenu(menu) {chrome.contextMenus.create({id: menu.id,title: menu.title,contexts: ["selection"],parentId: menu.parentId,},function () {if (Array.isArray(menu.children)) {menu.children.forEach(createMenu);}});}menuList.forEach(createMenu);
});

定義了一個菜單列表 menuList ,通過遞歸 createMenu 創建菜單。同時,我們將 contexts 設置了 selection ,即在選中文本時才顯示菜單。

效果如下:
屏幕截圖 2024-04-01 152913.png

documentUrlPatterns:表示哪些網址下可以看到右鍵菜單。
假如:我們只想讓百度界面才能看到菜單,可以將 documentUrlPatterns 設置如下:
image.png
documentUrlPatterns 支持通配符,*: 匹配任何字符數量的任何字符序列。

targetUrlPatterns:它的作用和 documentUrlPatterns 類似,都是限制哪些內容可以看到菜單的,區別是:

  • documentUrlPatterns 是針對網頁的
  • targetUrlPatterns 是針對頁面上的某些元素(如鏈接、圖片)的 URL 匹配
2、chrome.contextMenus.update

更新菜單,除了 id 不能更新外,其他創建選項均可以更新,比如:更新菜單標題 title
image.png

  chrome.contextMenus.create({id: "1",title: "更新菜單",});// 更新菜單function updateMenu(id, title) {chrome.contextMenus.update(id, {title,});}updateMenu("1", "更新菜單2");
3、chrome.contextMenus.remove

移除指定菜單項

chrome.contextMenus.remove("id");

這個 API 比較簡單,就不單獨舉例了。

4、chrome.contextMenus.removeAll

移除所有菜單項

chrome.contextMenus.removeAll()

代碼地址:傳送門

總結
  • 使用右鍵菜單要開啟權限:contextMenus
  • chrome.contextMenus.create:創建菜單
  • chrome.contextMenus.update:更新菜單
  • chrome.contextMenus.remove:移除菜單
  • chrome.contextMenus.removeAll:移除全部菜單

創作不易,動動您發財的小手,點贊關注一波,支持我創作更多對您有幫助的文章!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/36014.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/36014.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/36014.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

本地讀取classNames txt文件

通過本地讀取classNames,來減少程序修改代碼,提高了程序的拓展性和自定義化。 步驟: 1、輸入本地路徑,分割字符串。 2、將className按順序放入vector容器中。 3、將vector賦值給classNmaes;獲取classNames.size(),賦值給CLASSES;這樣,類別個數和類別都已經賦值完成。…

Python | Leetcode Python題解之第199題二叉樹的右視圖

題目: 題解: class Solution:def rightSideView(self, root: TreeNode) -> List[int]:rightmost_value_at_depth dict() # 深度為索引,存放節點的值max_depth -1stack [(root, 0)]while stack:node, depth stack.pop()if node is not…

第N8周:seq2seq翻譯實戰-Pytorch復現

🍨 本文為🔗365天深度學習訓練營 中的學習記錄博客🍖 原作者:K同學啊 | 接輔導、項目定制 一、前期準備 from __future__ import unicode_literals, print_function, division from io import open import unicodedata import s…

什么是堡壘機(運維審計系統)?

一、堡壘機是什么 1.1 堡壘機的來由 堡壘機是從跳板機(也叫前置機)的概念演變過來的。早在2000年左右的時候,一些中大型企業為了能對運維人員的遠程登錄進行集中管理,會在機房部署一臺跳板機。 跳板機其實就是一臺lunix/windows…

50、基于NARX神經網絡的磁懸浮建模(matlab)

1、NARX神經網絡簡介 NARX(非線性自回歸外部輸入)神經網絡是一種用于非線性建模和預測的神經網絡結構。與傳統的自回歸模型不同,NARX網絡可以接收外部輸入來影響輸出結果,從而更好地捕捉系統的復雜性和非線性特征。 NARX神經網絡…

NodeJs之npm、yarn、pnpm設置最新的淘寶鏡像下載源

NodeJs之npm、yarn、pnpm設置最新的淘寶鏡像下載源 文章目錄 NodeJs之npm、yarn、pnpm設置最新的淘寶鏡像下載源1. 查看默認的下載源1. npm2. yarn3. pnpm 2. 設置最新的淘寶鏡像地址1. npm2. yarn3. pnpm 1. 查看默認的下載源 1. npm C:\Users\jinshengyuan>npm get regi…

STM32 SPI實戰篇:驅動W25Q64 Flash存儲器的技巧與方法

摘要 在嵌入式系統開發中,非易失性存儲是必不可少的一部分。W25Q64作為SPI Flash存儲器的一種,以其較高的存儲密度和擦寫次數受到廣泛應用。本文將深入探討STM32通過SPI驅動W25Q64的實戰技巧和方法,包括硬件連接、SPI配置、讀寫操作&#xf…

競賽選題 python+深度學習+opencv實現植物識別算法系統

0 前言 🔥 優質競賽項目系列,今天要分享的是 🚩 基于深度學習的植物識別算法研究與實現 🥇學長這里給一個題目綜合評分(每項滿分5分) 難度系數:4分工作量:4分創新點:4分 🧿 更多…

基于Java微信小程序自駕游拼團設計和實現(源碼+LW+調試文檔+講解等)

💗博主介紹:?全網粉絲10W,CSDN作者、博客專家、全棧領域優質創作者,博客之星、平臺優質作者、專注于Java、小程序技術領域和畢業項目實戰?💗 🌟文末獲取源碼數據庫🌟感興趣的可以先收藏起來,還…

27. 高級特性(下)

目錄 一、為了類型安全和抽象而使用 newtype 模式二、使用類型別名創建類型同義詞2.1 使用type關鍵賦予現有類型一個別名2.2 減少重復2.3 與Result<T, E>結合使用2.4 從不返回的 never type 三、高級函數和閉包3.1 函數指針3.2 返回閉包 四、宏4.1 宏和函數的區別4.2 mac…

python基礎語法 003-3 數據類型元組

1 元組 1.1 元組含義 1.1.1 元組的表示 #元組的表示方法:() names ("xiaoyun", "xiaoming") print(names)--結果------- (xiaoyun, xiaoming) 1.1.2 空元組 #空元組 names () print(type(names)) print(len(names))----------------結果--------- &l…

安裝vue開發者工具

瀏覽器控制臺提示&#xff1a; 打開網址 GitHub - vuejs/devtools: ?? Browser devtools extension for debugging Vue.js applications. 點擊添加 上圖地址&#xff1a;Installation | Vue Devtools 安裝好了

Spring Boot中如何使用Flyway進行數據庫版本控制

Spring Boot中如何使用Flyway進行數據庫版本控制 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;在現代的軟件開發中&#xff0c;數據庫版本控制是保證應用程序…

群體優化算法---石墨烯優化算法介紹以及在期權定價上的應用(Black-Scholes模型來計算歐式期權的理論價格)

介紹 石墨烯算法是一種新興的優化算法&#xff0c;靈感來自于石墨烯的結構和特性。石墨烯是一種由碳原子構成的二維蜂窩狀晶格結構&#xff0c;具有優異的機械、電學和熱學性能。石墨烯算法通過模擬石墨烯原子之間的相互作用和遷移&#xff0c;來求解復雜的優化問題 基本概念…

K8S -理解StatefulSet - 部署有狀態應用

什么是 有狀態服務和 無狀態服務 有狀態服務&#xff08;Stateful Service&#xff09;&#xff1a; 有狀態服務是指在處理請求期間維護和跟蹤用戶狀態或會話信息的服務。這意味著服務在多個請求之間保持狀態&#xff0c;并且需要在請求之間共享和使用這些狀態信息。通常&…

Websocket在Java中的實踐——握手攔截器

在《Websocket在Java中的實踐——最小可行案例》一文中&#xff0c;我們看到如何用最簡單的方式實現Websocket通信。本文中&#xff0c;我們將介紹如何在握手前后進行干涉&#xff0c;以定制一些特殊需求。 在《Websocket在Java中的實踐——最小可行案例》的基礎上&#xff0c;…

PID原理及控制算法詳解

文章目錄 1. 概念 1.1 PID框圖 1.2 具體示例&#xff1a;無人機高度控制 2. PID原理 3. 常用術語 4. 計算過程 4.1 比例控制&#xff08;Proportional&#xff09; 4.2 積分控制&#xff08;Integral&#xff09; 4.3 微分控制&#xff08;Derivative&#xff09; 5.…

windows@文件高級共享設置@網絡發現功能@從資源管理器網絡中訪問遠程桌面

文章目錄 高級共享設置常用選項其他選項操作界面說明 網絡類型檢查和設置(專用網絡和公用網絡)&#x1f47a;Note 高級共享設置和防火墻&#x1f47a;命令行方式使用圖形界面方式配置 網絡發現網絡發現功能的詳細介紹網絡發現的作用&#x1f47a;網絡發現的工作原理啟用和配置網…

SOC和SOH聯合估計 | 基于集成ELM的鋰離子電池充電截止電壓下的SOC和SOH聯合估計

目錄 研究概述研究內容研究路線研究介紹研究概述 充電截止電壓是大多數電動汽車用戶充電都會經歷的電壓點。針對傳統安時積分法忽略初始容量誤差和電池老化等一系列待優化的問題,提出了雙層集成極限學習機(extreme learning machine, ELM)算法,實現鋰離子電池充電截止電壓下…

【Python實戰因果推斷】2_因果效應異質性2

目錄 CATE with Regression Evaluating CATE Predictions CATE with Regression 我想你可能已經預料到了&#xff1a;與應用因果推理中的大多數情況一樣&#xff0c;答案往往從線性回歸開始。但在走這條路之前&#xff0c;讓我們把事情變得更具體一些。假設你在一家遍布全國的…