0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

写一个Chrome浏览器插件

京东云 来源:jf_75140285 作者:jf_75140285 2024-11-18 17:12 次阅读

一、什么是浏览器插件

浏览器插件是依附于浏览器,用来拓展网页能力的程序。插件具有监听浏览器事件、获取和修改网页元素、拦截网络请求、添加快捷菜单等功能。使用浏览器插件可以实现很多有趣的功能。

二、浏览器插件有哪些种类

•以chromium为内核的浏览器插件如Chrome

•firefox浏览器插件

•safari浏览器插件

本文只介绍Chrome插件的原生开发流程。

三、插件目录介绍

wKgaomc7BPCAMqkPAAEGcp5T_Z4361.png

a的文件名 文件介绍
manifest 核心配置文件,配置插件平台版本、名称、权限、Aicon、Api权限、host权限等。
popup.html 插件弹出页面,原生html、css页面。
popup.js 插件页面的脚本文件。
popup.css 插件页面的样式文件
background.js 后台文件,可以监听浏览器事件,在浏览器后台持续运行。
content.js 插入到页面中的js脚本,可以监听DOM事件,操作DOM元素。

四、开始写一个插件

1. 配置manifest。

以下是一个基础的manifest配置

wKgZomc7BPKAcelRAAX-1hHDX3o841.png

2. 写一个插件的弹框界面popup.html

和写html页面一样,在body里面写元素,但是需要注意样式文件popup.css和脚本文件popup.js需要外部引入。

wKgaomc7BPOAI_FBAATEQ3mhtP4646.png

3. 写一个插件弹框界面的样式文件popup.css。

4. 写一个插件弹框界面的脚本文件popup.js。

脚本文件的主要作用在于响应插件弹窗的行为事件,并发送消息给内容脚本或者后台脚本。

以下代码是在popup.js中,监听id为tag元素的点击事件,获取当前窗口active标签页,并给此标签页推送一个message。

wKgZomc7BPWAVQeAAAOTimez9I8340.png

4. 写一个插件的内容脚本content.js

content.js会被插入到网页环境中,用于监听浏览器事件,读取和操作DOM元素。

以下代码是监听页面load事件,和接收来自第三步中send的message。


window.addEventListener("load", function () {
    // 监听页面load事件
})

chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) {
 console.log("-----------");
 if (request.greeting === "tag") {
    console.log(request.greeting)
 }
});

5. 写一个插件的后台脚本background.js

后台脚本会在浏览器窗口打开期间持续运行,监听浏览器事件,网络请求等。

以下代码是浏览器屏蔽漏某些url请求的实现。

wKgaomc7BPaAZCIVAAMl2qMOuM4596.png



把上述的几个文件创建完成之后就实现了一个简单的插件,然后直接安装到浏览器扩展即可。



五、解释几个消息发送和接收的Api

1. 获取指定的浏览器标签页:

chrome.tabs.query({ active: true, currentWindow: true }, function (tabs) {})

2. 向指定标签页中的内容脚本发送一条消息,其中包含在发送回响应时运行的可选回调函数。在当前扩展程序的指定标签页中运行的每个内容脚本中都会触发 runtime.onMessage 事件。

chrome.tabs.sendMessage(tabs[0].id, { greeting: "tag-remove" }, function (response) { console.log(response); });

3. 向扩展程序或其他扩展程序/应用中的事件监听器发送一条消息。请注意,扩展程序无法使用此方法向内容脚本发送消息。如需向内容脚本发送消息,请使用

chrome.runtime.sendMessage( extensionId?: string, message: any, options?: object, callback?: function,)

4. onMessage,通过扩展程序进程(通过 runtime.sendMessage)或内容脚本(通过 tabs.sendMessage)发送消息时触发。

chrome.runtime.onMessage.addListener( callback: function,)

想了解其他浏览器插件Api,请点击跳转

六、接下来让我们丰富插件的能力

1. 实时删除页面上的元素,我们经常会遇到一些烦人的广告,删掉他。广告一般都是有固定的元素节点的,找到元素节点的class或者id,按以下处理。

以百度一下页面举例,以下代码实时监听网页元素,发现class为s-p-top的元素后就会删除改元素,这里我给被删除元素的位置加了一个红色边框用来测试,实际使用中可以删除添加红框的代码。

在content.js中添加以下代码:

wKgZomc7BPiAJFc0AAjKHOlc644824.png

通过下面两个图对比可以看出使用插件后百度图片被删除了:

wKgaomc7BPmAH5kRAAPM-MQ_xaQ129.png

wKgaomc7BPyAQjDvAANCun_O_Y8035.png

2. 有人不习惯点开右上角插件再点击功能按钮,怎么办呢,简单,给浏览器右键菜单添加快捷键。

以下代码为添加浏览器右键菜单的快捷键,并监听菜单点击事件,可在menu2中发起请求。

在background.js中:

wKgZomc7BP2AU0rrAAZnVLWXk9M005.png

效果如下:

wKgaomc7BP6Ac1rLAAMtNdh-FMg549.png

3. 还是拦截广告,广告可能出现在iframe中,但是呢我不想使用删除DOM的方式,怎么办呢,那就直接拦截网络请求。

在background.js中:

wKgZomc7BQCAF9coAAN771BCkc0758.png

我们还以baidu.com为例,在MDN中测试,修改iframe src的值为baidu.com.

使用插件前结果如下:

wKgaoWc7BQGASLILAAKSO1TlPjQ097.png

使用插件后结果如下,可以发现iframe中没有渲染baidu.com,并且在network中可以看到baidu.com被屏蔽了:

wKgZoWc7BQKAL2mnAAZ2aWIcEFQ761.png

4. 自定义一个自己的新开页

两步走

第一步:在manifest中定义newtab(就是一个html文件,这个文件会覆盖原生的浏览器新开页)

wKgaoWc7BQOAOHeCAAJadBaIF1Y663.png

第二步:创建newtab.html文件,可以在这个文件定义新开页的样式和js,且此样式文件和js文件不用添加到content_scripts中

wKgZoWc7BQaAJO-6AARQo79jH7I822.png

效果如下

5. 标记页面文本

在阅读网页文档时,经常会想标记一些重点文本,可以直接用扩展来实现:

在background.js中:

wKgZoWc7BQyAPkjVAATkW8sWH38700.png

在content.js中:

wKgaoWc7BQ2ASvOXAAWfada-aU0454.png

效果:

wKgZoWc7BRCAVbfjAAWI-XRuibw899.gif

功能先丰富到这里,后面再继续补充~

七、参考文档

chrome扩展参考文档

chrome Api文档

manifest权限配置文档

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 插件
    +关注

    关注

    0

    文章

    326

    浏览量

    22439
  • chrome浏览器
    +关注

    关注

    0

    文章

    11

    浏览量

    6921
收藏 人收藏

    评论

    相关推荐

    Chrome 15正式版浏览器登场

    `Google今天发布了Chrome 15正式版,Windows、Linux、Mac三大平台以及Chrome Frame浏览器内嵌框架用户均可更新至最新的Chrome 15.0.874
    发表于 10-26 18:49

    树莓派安装chrome浏览器的问题

    如题,在安装chrome浏览器的时候,出现如下图问题。怎么破?
    发表于 09-11 11:07

    安装了chrome浏览器,但还是很卡

    在论坛看到了发烧友大神说的关于浏览器的问题,我也就安装了chrome浏览器,但是还是卡爆了。CPU爆棚的说。。。
    发表于 09-12 16:44

    Chrome浏览器将在ARM内核运行,Google Andr

    Chrome浏览器将在ARM内核运行,Google Android如虎添翼 Google将为其新发布的x86浏览器开发适用于ARM处理
    发表于 09-05 10:57 1381次阅读

    视频监控系统跨浏览器插件的研究与实现

    针对目前视频监控系统的浏览器插件与非IE内核的浏览器不兼容的问题,本文采用基于FireBreath开发框架开发跨浏览器插件系统的方法,使
    发表于 12-18 16:03 5次下载

    四大浏览器续航对决,结果Chrome浏览器完胜

    近日,YouTube频道UP主Linus Tech Tips进行了次四大浏览器续航对决,结果Chrome浏览器完胜。
    发表于 06-27 10:16 1395次阅读

    Chrome成为浏览器市场的霸主 微软Edge惨淡收场

    浏览器竞争的赛道上,微软Edge算是彻底输了。微软为与Chrome竞争重新启动Edge浏览器,但结果确实不如人意。如今Chrome已彻底统治浏览器
    发表于 02-03 10:23 864次阅读

    谷歌浏览器 Chrome 发布 Linux 版本即将跟进

    把地址栏在上标签在下的传统,界面相当简洁,而且界面很有 Google 的风格,与我们平时所用的 Google 产品的配色方案是类似的。 先要下载安装程序,然后安装程序会连接到网络下载浏览器需要
    发表于 04-02 14:38 537次阅读

    Chrome浏览器隐私设置重新设计后有什么不同

    Chromium小组重新设计了Chrome浏览器的“隐私设置”或Chrome 80中的“隐私和安全设置”卡。
    的头像 发表于 11-16 09:37 2292次阅读

    谷歌计划通过Lacros将Chrome浏览器Chrome系统分离

    Chromebook 用户可能直以来有烦恼:由于 Chrome 浏览器Chrome O
    的头像 发表于 09-14 14:04 2131次阅读

    五大Chrome神级插件,让Chrome浏览器更加好用十倍

    Chrome谷歌浏览器是很多人心目中的NO.1,虽然它很好用,但难免还是有些功能顾及不到。这时候,就需要插件来帮忙。今天介绍5Chrome
    的头像 发表于 09-17 14:05 3180次阅读

    谷歌 Chrome 解决性能问题,增大浏览器缓存

    外媒 Bleeping Computer 报道,谷歌 Chrome 浏览器开发人员最近解决了安全问题,按网站对浏览器缓存进行分区,而不是
    的头像 发表于 12-28 11:58 3179次阅读

    Chrome浏览器插件v1.9.0发布 使用了最简单的JavaScript代码解析

    距 OSCHINA Chrome 浏览器插件 发布 上一个版本已经8月了,这段时间 OSCHINA 社区也做了多次改版,首屈
    的头像 发表于 01-08 11:39 2021次阅读
    <b class='flag-5'>Chrome</b><b class='flag-5'>浏览器</b><b class='flag-5'>插件</b>v1.9.0发布 使用了最简单的JavaScript代码解析

    暴力猴浏览器插件

    暴力猴浏览器插件
    发表于 05-29 11:20 6次下载

    浏览器原理解析Chrome常见插件的实现思路

    近期Chrome进程架构 从图中可以看出,最新的 Chrome 浏览器包括:1 浏览器主进程、1
    的头像 发表于 12-08 14:25 831次阅读
    从<b class='flag-5'>浏览器</b>原理解析<b class='flag-5'>Chrome</b>常见<b class='flag-5'>插件</b>的实现思路