Firefox插件(拓展)开发

news/2024/5/20 13:54:23/文章来源:https://blog.csdn.net/hao_13/article/details/130979265

目录

0、一些概念

1、创建一个项目

2、创建内容脚本

3、将拓展临时添加到浏览器中进行测试

3-1、Ctrl+Shift+A 或:

3-2、选择调试附加组件

 3-3、选择临时加载附加组件

3-4、选择我们项目中的 manifest.json 文件打开

3-5、如果打开成功:

4、继续开发和调试

 5、添加拓展按钮到工具栏

6、为在浏览器工具栏中的拓展按钮指定一个弹出窗

 7、为弹出窗中的按钮绑定点击事件

8、插件侧边栏的开启和切换

9、插件配置侧边栏

10、添加并处理侧边栏元素事件

11、通过右键菜单来取消事件

12、参考


0、关于插件中脚本的一些概念

JavaScript编写插件时,通常分为以下几个脚本:

1. Content Script(内容脚本):用于操作网页内容,可以访问DOM和页面元素,可以修改页面样式和行为,与页面共享同一个JavaScript环境。

2. Background Script(后台脚本):用于处理插件的后台任务,例如处理网络请求、管理插件状态、与其他插件通信等,与页面不共享JavaScript环境。

3. Popup Script(弹出窗口脚本):用于处理插件弹出窗口的交互逻辑,例如响应用户点击事件、发送消息给后台脚本等。

4. Options Script(选项页面脚本):用于处理插件选项页面的交互逻辑,例如保存用户设置、发送消息给后台脚本等。

1、创建一个项目

        新建一个目录,在目录下创建一个 manifest.json 配置文件,写入最简单的基本配置:

/* 注意,这是一个 json 文件,文件里面不能有注释性的内容 */
{"manifest_version": 2,      // 必须是2或3"name": "FirstTest",        // 拓展的名称"version": "0.0.1",         // 拓展的版本号"description": "my first test",    // 对当前拓展的描述"icons": {                 // 配置拓展的图标"48": "./java.jpg","96": "./java.jpg"},"content_scripts": [       // 内容脚本配置{"matches": ["*://*/*"],    // 匹配应该当前拓展的URL,当前是匹配全部URL"js": ["index.js"]         // 脚本文件}]
}

2、创建内容脚本

        在项目目录下创建一个 index.js 写一个简单的内容脚本。

        这个 index.js 就是manifest.json文件中("content_scripts"."js")[1]中的内容(名字要一致才匹配到)。

document.body.style.backgroundColor = '#ff8f0029';

        这个index.js 文件只写一段代码,内容是让 body 的背景色变成一种浅肉色。

3、将拓展临时添加到浏览器中进行测试

        在火狐中添加:

3-1、Ctrl+Shift+A 或:

3-2、选择调试附加组件

 3-3、选择临时加载附加组件

3-4、选择我们项目中的 manifest.json 文件打开

        在谷歌浏览器中是要将整个项目的文件夹导入

3-5、如果打开成功:

         此时我们打开其他的网页查看,如进入到百度:

        可以看到网页加载完成后,在短暂的时间内背景色会变成上面的颜色,页面的body元素确实添加了我们在内容脚本中设置的样式。

4、继续开发和调试

        当我们完成了上述的步骤之后,我们可以继续在我们的项目中进行开发。

        当我们需要继续到浏览器中进行调试和观察的时候,只需要将文件保存,然后到浏览器临时扩展处点击重载按钮,即可实现同步(确保项目文件路径没有改变)。

 5、添加拓展按钮到工具栏

        在 manifest.json 文件中添加:

    "browser_action": {"default_icon": {        // 指定图标"19": "./java.jpg","38": "./java.jpg"},"default_title": "这个是工具栏按钮"}

6、为在浏览器工具栏中的拓展按钮指定一个弹出窗

        在项目中新建一个 popup 文件夹,在文件夹下建立一个 popup.html 文件,在里面编写弹出窗的html代码,也可以编写与之相关的css、js代码。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><style>html,body{width: 100px;box-sizing: border-box;/* padding: 5px 8px; */}.popup-content{width: 100%;display: flex;flex-direction: column;justify-content: center;align-items: center;}.popup-content > button{width: 95%;height: 35px;border-radius: 12px;border: 0;box-shadow: 0 1px 10px 1px #cccfff;margin: 5px 0;background-color: rgb(188, 209, 249);}button:hover{cursor: pointer;}</style>
</head>
<body><div class="popup-content"><button>选项A</button><button>选项B</button><button>选项C</button></div>
</body>
</html>

        在 manifest.json 文件中添加 default_popup:

    "browser_action": {"default_icon": {"19": "./java.jpg","38": "./java.jpg"},"default_title": "这个是工具栏按钮","default_popup": "popup/popup.html"  // 添加这一句,指定弹出窗的html文件}

         到临时拓展中对当前拓展进行重载,然后点击工具栏对应的按钮,就可以看到弹出窗:

 7、为弹出窗中的按钮绑定点击事件

        刚才的 .html 文件中提供了三个按钮,现在试图为每一个按钮绑定一个点击事件,当用户点击到一个按钮时,切换当前页面的 body 元素的背景色。

        先修改 .html 文件,为按钮添加一个相同的类名以及不同的innerText:

    <div id="popup-content"><button class="popup-btn">#ff00002e</button><button class="popup-btn">#0000ff21</button><button class="popup-btn">#2cff0026</button></div>

        在 popup 目录下新建一个 popup.js 文件,然后在.html 文件中引入:

<script src="./popup.js"></script>

        编写 popup.js 文件来实现要求:

// 这里的 document 就是我们 编写的 popup.html
let btns = document.querySelectorAll('.popup-btn');// 这里的打印是在调试插件的控制台中打印
console.log('btns:', btns);// 为每一个 button 绑定事件
btns.forEach(e => {e.addEventListener('click', ()=>{// 这里的 innerText 就是一个十六进制的颜色值action(e.innerText);})
})function action(color){// 使用 tabs 可以与浏览器系统标签进行交互/*tabs.query 获取具有指定属性的所有选项卡,如果未指定任何属性,则获取所有选项卡配置对象的 active:true 表示要获取的选项卡在页面中处于活动状态currentWindow:true 表示在当前的窗口中进行操作*/browser.tabs.query({active: true, currentWindow: true}, tabs => {// 为当前窗口注入脚本browser.tabs.executeScript({code: `// 此时是在页面的控制台中打印,操作的是当前浏览的页面 console.log('color: ${color}');document.body.style.backgroundColor = '${color}';`});});
}

        由于要使用到 tab 这个API,需要在manifest.json 文件中添加许可:

    "permissions":["activeTab"]

        到临时拓展的位置,点击当前临时拓展模块上的“检查”按钮,即可打开插件开发的检查调试工具。

        当点击工具栏上的插件图标时, 会在插件的开发者工具的控制台中打印 popup.html 中三个按钮。

        当点击插件弹窗的第一个按钮时,页面背景色改变,同时在控制台中输出当前背景色号:

 

        点击第二个按钮后:

8、插件侧边栏的开启和切换

 

         将侧栏拖动到工具栏的位置:

 

         点击该侧栏按钮就能打开或关闭插件的侧边栏(只有插件提供了侧边栏,才有侧边栏的服务)。

9、插件配置侧边栏

        在 manifest.json 中添加 “sidebar_action” 配置项,default_title 设置侧边栏的名称为“My sidebar”,default_panel 设置面板的界面文件为指定的html文件,“default_icon”设置侧边栏的图标。

    "sidebar_action": {"default_title": "My sidebar","default_panel": "./sidebar/sidebar.html","default_icon": "./sidebar/sidebar_icon.png"},

         在项目文件夹下创建一个 sidebar 目录,并在该目录下创建一个 sidebar.html 文件,用来配置侧边栏的界面。

        写一个简单的侧边栏界面:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><style>.container{border: 3px solid pink;width: 100%;height: 100vh;box-sizing: border-box;}.top-btns{width: 100%;height: 50px;display: flex;justify-content: space-around;padding: 5px 8px;}.top-btns > button{outline: none;padding: 3px 12px;border-radius: 8px;box-shadow: 0 1px 10px 2px #eeefff;border: 0;background-color: rgb(209, 165, 251);}.top-btns > button:hover{cursor: pointer;box-shadow: 0 1px 5px .5px #cacaca;}</style>
</head>
<body><div class="container"><div class="top-btns"><button>btn A</button><button>btn B</button></div></div>
</body>
</html>

         在这里可以切换插件的侧边栏,当前只有一个插件(就是现在这个插件)提供了侧边栏服务,所以没有其他可以切换。

 

10、添加并处理侧边栏元素事件

        在 sidebar.html 文件中添加 script 标签,引入script 脚本处理侧边栏事件:

<script src="./index.js"></script>

        在 index.js 文件中,为两个按钮添加点击事件。当点击第一个按钮后,操作鼠标在当前浏览的页面中滑动,当鼠标悬浮在某元素上时,为该元素进行高亮描边。当点击第二个按钮时,取消该事件,操作鼠标在网页上滑动时,悬浮在某元素上,元素的 border 不再改变。

// 获取到两个按钮
const btns = document.querySelectorAll('.top-btns button');// 获取当前激活的标签页面
browser.tabs.query({active: true, currentWindow: true}).then((logTabs,onError)=>{// 然后往当前页面中注入内容脚本,就行操作当前页面一样browser.tabs.executeScript({code:`// 将函数挂在window身上,可以让下次注入的脚本共享此函数window.mouseOverFunc = (e) => {         // 鼠标悬浮let target = e.target;target.style.border= '3px ridge red';    // 当前鼠标悬浮的元素描边}window.mouseOutFunc = (e) => {          // 鼠标离开let target = e.target;target.style.border = '';}`})
})// 点击第一个按钮 开启悬浮高亮
btns[0].addEventListener('click',()=>{browser.tabs.query({active: true, currentWindow: true}).then((logTabs,onError)=>{browser.tabs.executeScript({code:`// 注入的脚本可以共享 mouseOverFunc、mouseOutFunc 函数document.addEventListener('mouseover', mouseOverFunc)document.addEventListener('mouseout', mouseOutFunc)`})})
})// 点击第二个按钮取消悬浮高亮
btns[1].addEventListener('click',()=>{browser.tabs.query({active: true, currentWindow: true}, tabs => {// 为当前窗口注入脚本browser.tabs.executeScript({code: `// 移除鼠标悬浮和离开的borderdocument.removeEventListener('mouseover',mouseOverFunc);document.removeEventListener('mouseout',mouseOutFunc);`});});
})

 

11、通过右键菜单来取消事件

         继续在 index.js 文件中增加代码:

// 创建右键菜单选项,用于停止选择
browser.contextMenus.create({id: "stop-select-element",              // id在菜单中唯一title: "stop select element",           // 名称contexts: ["page", "selection", "link"]     // 在哪些情况下有该选项
});
// 监听右键菜单选项被点击
browser.contextMenus.onClicked.addListener((info,tab)=>{// 判断是否执行if(info.menuItemId === 'stop-select-element'){// 注入脚本,移除事件监听器browser.tabs.query({active:true, currentWindow:true}).then(()=>{browser.tabs.executeScript({code:`document.removeEventListener('mouseover',mouseOverFunc);document.removeEventListener('mouseout',mouseOutFunc);`})})}
})

 

12、参考

你的第一个拓展 - Mozilla | MDN 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_501451.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring高手之路1——深入理解与实现IOC依赖查找与依赖注入

本文从xml开始讲解&#xff0c;注解后面给出 文章目录 1. 一个最基本的 IOC 依赖查找实例2. IOC 的两种实现方式2.1 依赖查找&#xff08;Dependency Lookup&#xff09;2.2 依赖注入&#xff08;Dependency Injection&#xff09; 3. 在三层架构中的 service 层与 dao 层体会依…

chatgpt赋能python:Python安装Gurobi优化器详细步骤

Python安装Gurobi优化器详细步骤 如果你是一个数据科学家或者运筹学专业的研究者&#xff0c;你肯定会经常接触到优化问题。Gurobi是一个流行的线性与整数规划优化软件包&#xff0c;它提供了出色的线性规划和整数规划支持&#xff0c;速度快&#xff0c;准确度高&#xff0c;…

chatgpt赋能python:Python安装好后怎么写代码?

Python安装好后怎么写代码&#xff1f; Python是一种高级编程语言&#xff0c;已成为众多开发者的首选工具。根据一些统计数据&#xff0c;Python排名全球第三的流行语言&#xff0c;已经成为Web开发、数据科学和人工智能领域的首选语言。如果您刚刚安装了Python&#xff0c;那…

chatgpt赋能python:Python字典通过键找值:什么是Python字典?

Python字典通过键找值&#xff1a;什么是Python字典&#xff1f; Python字典是一种非常有用的数据类型&#xff0c;可以通过键值对方式存储和访问数据。它是Python的一种内置数据类型&#xff0c;可以在编程中非常方便地存储和操作数据。 Python字典可以存储任意类型的数据&a…

Linux命令学习之文本查看命令cat、head和tail

for i in {1..100} do echo $i >> good.txt done把1到100写入到good.txt文件中。接下来使用good.txt这个文件来演示查看文本查看命令。 cat man cat可以看一下帮助使用说明&#xff0c;按q可以退出。 cat是连接文件并把文件内容输出到标准输出上。cat good.txt就可以…

Linux 内存管理6——slab内存池的创建初始化过程

在上篇文章 中&#xff0c;笔者带大家从一个最简单的物理内存页开始&#xff0c;一步一步演进 slab cache 的架构&#xff0c;最终得到了一副 slab cache 完整的架构图&#xff1a; 在本文的内容中&#xff0c;笔者会带大家到内核源码实现中&#xff0c;来看一下 slab cache 在…

chatgpt赋能python:Python如何设置输入的SEO

Python如何设置输入的SEO Python是一种高级的编程语言&#xff0c;具有容易上手、可扩展和开源等特点&#xff0c;因此在软件开发过程中得到广泛的应用。然而&#xff0c;如果您想让您的Python项目在搜索引擎上获得更好的排名和流量&#xff0c;您需要考虑如何设置输入的SEO。…

初识TypeScript -基础一

前言 在开始工作之前&#xff0c;就听朋友提过TypeScript&#xff0c;之前也没多想学习&#xff0c;直到vue3出来之后&#xff0c;感觉TypeScript 后面会成为主流&#xff0c;只能硬着头皮学学吧。 读完本片文章&#xff0c;你会收获 1、TypeScript的历史及其优势 2、TypeScri…

chatgpt赋能python:Python如何抓取数据

Python如何抓取数据 介绍 Python是一种功能强大的编程语言&#xff0c;它被广泛使用于网络抓取和数据分析。无论您是想要从网站上抓取数据&#xff0c;还是使用API抓取数据&#xff0c;Python都是一种非常适合的工具。在本文中&#xff0c;我们将介绍Python如何抓取数据&…

SciencePub学术 | 智能交通类重点SCIEI征稿中

SciencePub学术刊源推荐: 智能交通类SCI&EI征稿中&#xff01;进展顺利&#xff0c;录用率高&#xff0c;连续十年IF稳定上升。信息如下&#xff0c;录满为止&#xff1a; 一、期刊概况&#xff1a; 【期刊简介】IF&#xff1a;4.0-4.5↑&#xff0c; JCR 2区&#xff0c;…

【Linux服务器编程总结】网络编程基础知识 (udp初级)

一.预备知识 1.主机字节序和网络字节序: 其实本质就是大小端。通常在网络传输的时候会将要发送的数据转同一转换成大端后再发送。在linux中提供了如下四个函数进行大小端转换。 2. 网络套接字&#xff1a; 我们在网络编程的时候会使用到socktet 套接字。对此我们需要了解so…

QT CTK插件开发(六) 多对一插件

CTK在软件的开发过程中可以很好的降低复杂性、使用 CTK Plugin Framework 提供统一的框架来进行开发增加了复用性 将同一功能打包可以提供多个应用程序使用避免重复性工作、可以进行版本控制提供了良好的版本更新迭代需求、并且支持动态热拔插 动态更新、开发更加简单快捷 方便…

chatgpt赋能python:Python如何进行算术运算

Python如何进行算术运算 Python是一种高级编程语言&#xff0c;适用于不同的应用场景&#xff0c;尤其是数据科学和机器学习。Python拥有强大的算术运算能力&#xff0c;使得它成为处理大规模计算任务的首选语言。 基本运算符 Python中的基本运算符包括加法(), 减法(-), 乘法…

chatgpt赋能python:Python如何优化SEO?

Python如何优化SEO&#xff1f; Python已经成为一种非常流行的编程语言。专业人士使用Python编写众多应用程序&#xff0c;将其应用于各种行业和领域。众所周知&#xff0c;搜索引擎是市场营销的重要组成部分。SEO是在网站和搜索引擎结果页面上提高网站排名的过程。在这个过程…

论文中文翻译——kAFL Hardware-Assisted Feedback Fuzzing for OS Kernels

本论文相关内容 论文下载地址——26th USENIX Security Symposium论文中文翻译——kAFL Hardware-Assisted Feedback Fuzzing for OS Kernels 文章目录 本论文相关内容前言kAFL&#xff1a;操作系统内核的硬件辅助反馈Fuzzing作者信息论文来源主办方信息摘要1 引言2 技术背景2…

【ArcGIS Pro二次开发】(34):从字符串中提取中文、英文、数字与特殊符号

这是一个基于字段计算的工具。 有时候我们会遇到一些混杂着各种中文、英文、数字、特殊符号的文字&#xff0c;这个工具的目的是从这些复杂文字中提取出想要的特定文字。 比如说从CAD测绘图中可以读取到类似【混3】、【砖2】的文字&#xff0c;如果想要从中提取出层数或结构&…

Agile | 聊聊敏捷开发

什么是敏捷开发 敏捷开发是一种迭代和增量的项目管理方法&#xff0c;优先考虑适应性、协作和快速交付&#xff0c;而不是遵循严格的计划[0]。它是在《敏捷软件开发宣言》和《12项原则》中表达的一组价值观和原则[1]。敏捷是基于这些价值观和原则的一组框架和实践的总称。敏捷…

C++11中条件标量和互斥锁应用出现死锁思考

条件变量和互斥锁在多线程同步过程中经常被使用&#xff0c;以下测试程序测试其使用。 目录 1.测试程序1 2.测试程序2 3.运行结果思考 1.测试程序1 #include <mutex> #include <deque> #include <iostream> #include <thread> #include <condi…

Day_43插入排序

目录 一. 关于插入排序 1. 排序的定义 2. 插入排序 二. 插入排序的实现过程 三. 代码实现过程 1. 插入排序核心代码 四. 代码展示 五. 数据测试 六. 总结 一. 关于插入排序 1. 排序的定义 排序&#xff0c;就是重新排列表中的元素&#xff0c;使表中的元素满足按关键字有序…

chatgpt赋能python:Python如何获取图片的尺寸

Python如何获取图片的尺寸 如果你在使用Python编程&#xff0c;常常需要获取图片的尺寸&#xff0c;本文将介绍如何使用Python获取图片的尺寸&#xff0c;同时还会介绍一些常用的Python库用于图像处理。 PIL库 PIL&#xff08;Python Imaging Library&#xff09;是Python中…