浏览器家园

TAG标签|网站导航| 手机访问:m.liulanqi.com

当前位置:首页ChromeChrome开发 → 一个简单的chrome拓展程序开发

一个简单的chrome拓展程序开发

时间:2023-06-27 11:03:50来源:整理作者:浏览器知识手机版

最近突然觉得有些常用的功能可以写成浏览器插件,就不用把代码放到console控制台运行了。只要点击插件图标就可以自动运行。会方便很多。就去查了下chrome插件开发教程。本质上讲,chrome插件就是以一些特殊的方式运行一些特定的html,css,JavaScript代码,前端同学们学起来还是很容易的。

比较好的中文的参考资料:
1.360翻译的文档:http://open.chrome.360.cn/ext…
2.Chrome扩展及应用开发:http://www.ituring.com.cn/min…

我们做一个简单的插件:实现点击插件图标可以给页面上所有的a标签加上一个target=”_blank”,让点所有链接都在新页面打开。
我们开发的应用这样使用:
图片描述

1.建立一个文件夹。a chrome plugin。
2.新建配置文件 manifest.json。前端同学们对于这样的配置文件一定不陌生。
里同包含了版本号,插件名称,默认页面,content_scripts,permissions等基本信息。
这个文件能将我们插件中的的js,css,JavaScript文件组织起来。
具体每个参数的含义见文档:http://open.chrome.360.cn/ext…
代码:

{
    "manifest_version": 2,
    "name": "A",
    "version": "1.0",
    "description": "新标签打开链接",
    "browser_action": {
        "default_popup": "popup.html"
    },
    "content_scripts":[
        {
            "matches": ["http://*/*","https://*/*"],
            "js": ["back.js"],
            "run_at":"document_end"
        }
    ],
    "permissions": [
        "tabs"
    ]
}

3.建立文件。popup.html。
对应配置文件中的 “default_popup”: “popup.html”。
图片描述
点图标的时候我们会加载运行这个html,运行这个html引入的js。
这是一个普通的html页面。里面可以写css。也可以加载JavaScript文件。也可以给里面的节点添加事件什么的。
不过这个文件以及加载的js无法访问当前我们打开的标签页中的dom节点。
代码:

<html>
<head>
    <meta charset="utf-8">
</head>
<body>
    这是popup.html里面。
</body>
</html>
<script src="popup.js"></script>

这里只用来加载一个js。

4.popup.js。 popup.html引入的js。这里我们用户它的做的事是向content_scripts中发送一个消息。相当于发一个命令。告诉content script,去办事吧。content_scripts的内容在后面,看完再回过来看一次这里。

    chrome.tabs.getSelected(null, function(tab) {
        chrome.tabs.sendRequest(tab.id, {greeting: "hello"}, function(response) {
            // console.log(response.farewell);
        });
    });

chrome.tabs.getSelected()这个函数能获取到当前标签的信息对象并传递给回调函数。
获取到tabId就是tab.id。可以自己console.log(tab)出来看一下。文章后面有对应调试控制台的打开方式。tab相关的接口可以查看:http://open.chrome.360.cn/ext… 很多接口都要用到这个参数:tabId ( integer ),其实就是用这个接口拿到tabId。

chrome.tabs.sendRequest()这个函数是向某个标签的content_script中发送一个消息。也需要tabId这个参数。chrome插件之间的通信接口可查看 :http://open.chrome.360.cn/ext…

5.back.js。也是我们这个插件中的content script。
这个文件是我们插入到当前标签页中运行的代码。它可以访问标签页面中的dom节点。
我们这里用它来是监听消息,消息来了就运行设置标签的函数。操作标签页中的dom节点。

对应配置文件中content_scripts下的back.js。
这个参数中的内容会被加载到当前打开的网页中,可以访问当前标签页的节点。
所以,我们对页面的操作往往会写在这个脚本里。有需要的话甚至可以加载个jQuery到里面。
但是这里的JavaScript与网页上原本的JavaScript不是一个环境下运行。具体区别可以自己去看开发文档。http://open.chrome.360.cn/ext…
代码:

function setA(){
    var aDoms = document.getElementsByTagName('a');
    var len = aDoms.length;
    for (var i = 0; i < len; i++) {
        aDoms[i].setAttribute("target","_blank")
    }
}
chrome.extension.onRequest.addListener(
    function(request, sender, sendResponse) {
        if (request.greeting == "hello"){
            setA();
            // sendResponse({farewell: "goodbye"});
        }else{
              // sendResponse({});
          }
      }
      );

可能比较要注意的一点是popup.html与content_script之间的通信。
popup.html向标签页中的content_script发送消息。
content_script接收到消息,执行操作。

6.调试方式:
popup.html加载的js调试。
右键点击插件图标,选择审查弹出内容。(或者在弹出框里右键点击检查。)会弹出一个控制台。
点source可以看到我们的html和js资源。
图片描述

content_script的调试:
打开页面控制台,点sources,然后点Contents scripts,可以看到浏览器插件会作用到页面的代码。
图片描述

注意每次修改了代码要重新加载插件。

这样我们就完成了一个简单的chrome插件。

github:https://github.com/liusaint/J…
本文同步发表在我的csdn博客上:http://blog.csdn.net/liusaint…

相关文章

  • 鸥朋浏览器,快速浏览网页,选择鸥朋浏览器!

    引言随着互联网技术的不断发展,人们浏览网页的习惯也在不断变化。在众多浏览器中,鸥朋浏览器受到越来越多的用户青睐。本文将介绍鸥朋浏览器的特点和优势,帮助大家更好地利用这一工具。2.鸥朋浏览器的特点鸥朋浏览器是一款专注于个性化定制的浏览器,在功能和用户体验上具有独特的特点。-高速浏览:鸥朋浏览器基于谷歌浏览器内核,拥有高速的页面加载速度和稳定性,不卡顿不崩溃,用户体验非常好。-安全保护:鸥朋浏览器在用户隐私保护方面非常重视,支持防止恶意插件、广告拦截、隐身模式等多项安全保护功能。-多样化定制:鸥朋浏览器提..
  • 电脑图片浏览器下载,电脑图片查看器免费下载,方便快捷的图片管理工具

    电脑图片浏览器下载电脑是我们最常用的工具之一,对于爱好摄影、美图制作的人来说,图片管理工具是非常必要的。在电脑上浏览图片时,我们需要一个好用的图片浏览器。在网上搜索,可以找到各种各样的图片浏览器。然而,为了避免下载带病毒或虚假的软件,我们需要选择安全可信的下载源,并仔细查看软件版本和说明以确保所下载的软件适用于我们的操作系统。2.电脑图片查看器免费下载有些好的图片浏览器需要购买才能使用。但在我们寻找图片查看器时,我们可以选择一些免费软件,例如GooglePhotos、Picasa等。这些图片软件带有许..

Copyright 2019-2029 www.liulanqi.com 【浏览器家园】 版权所有

浏览器家园_下载浏览器就到浏览器家园 | 专注MAC浏览器和Windows浏览器下载和使用介绍

声明: 所有软件和文章收集整理来自互联网 如有异议 请与本站联系 本站为非赢利性网站 不接受任何赞助和广告