因为平时上网都用chrome,但总感觉除了速度快,简洁以外总还有地方满足不了我的需要,然后找插件…后来发现,插件虽然海量但找个称心如意的也不是件容易的事儿,用在找插件的时间都能自己写一个了,于是,今年夏天开始的闲暇时间也写了几个,然后在应用中心断断续续发布了,这些插件原本是给自己用的,但也有几个用户专门找我提出了他们的需求。

从开始的不懂到现在三两下就能玩儿一个,走了点远路,今天在这里写下从开发到发布的简单流程,都是很简单的知识

一个可用的插件至少包括一个manifest.json和一个js文件

manifest.json

每个插件都有个manifest.json文件,此文件相当于C里的main(),文件结构是典型的json对象:

 1 {
2 "name": "应用名字",
3 "description":"应用的描述,以后发布到商城里,看到名字后第二看到的信息",
4 "version": "1.0",
5 "background": { "scripts": ["list.js","background.js"] },//后台运行的文件,比如相应插件消息的函数所在的文件等
6 "permissions": [
7 "tabs", "bookmarks","http://*/*","https://*/*" //插件运行“位置”,tab页、书签页、网页等
8 ],
9 "browser_action": {
10 "name": "Click to change the icon's color",
11 "default_title": "指向插件图标时显示的提示信息,可以有换行转义字符如\n—————————————\n第一行\n·第二行\n·第三行"
12 },
13 "icons": {"16": "icon16.png", "48": "icon48.png", "128": "icon128.png"},//配置插件各处显示的图标,其中包括在插件管理页面、应用商城中显示的图标等
14 "options_page": "options.html", //配置页面,无选项页面时不用设置
15 "manifest_version": 2, //这个必须是2,其他值在导致插件不支持新版本chrome浏览器
16 "web_accessible_resources":["greenrain.png","test.css","icon100.png"],//插件运行时,想在页面使用或引用的资源文件必须在此处标明一下,否则chrome不允许访问
17 "content_scripts": [
18 {//插件开始运行时立即导入的文件在此设置,必要的js文件在此处添加设置
19 "matches": ["http://*/*","https://*/*"],
20 "css": ["test.css"],
21 "js": ["jquery-1.7.2.min.js","xxxx.js"]
22 }
23 ]
24 }

本文件有一点需要注意:那就是,千万记得本文件不要加注释……正式发布时候没有提示的,只是提示不成功,郁闷(//和/**/都不行,上边的代码有注释是为了说明功能。)不要加注释啊不要加注释啊……

xxxx.js

需要执行的页面操作在本文件中完成,典型的包括dom操作、消息请求等

 1 (function ()
2 {
3 var profile = [],test=10;
4 alert("插件正在运行");
5 chrome.extension.sendRequest({ method: "getProfile" ,number:test}, function (response)
6 {//发起请求,获取基本配置
7 if (response.data != undefined && response.data != "")
8 {
9 alert("插件收到消息");
10 }
11 }
12 })();

background.js

通常用于处理接收消息、操作插件运行数据、浏览器行为调用等,比如图标显示、提醒。

 1 (function ()
2 {
3 chrome.browserAction.setIcon({ path: "img/icon0.png" });//图标
4 })();
5 var min = 0, max = 10, current=0;
6 function updateIcon(number)
7 {
8 chrome.browserAction.setIcon({ path: "icon" + current + ".png" });//切换图标
9
10 if(number){
11 if (number == 0) number = "";
12 chrome.browserAction.setBadgeText({ text: String(number) });//更新图标提示文字
13 }
14 else{
15 chrome.browserAction.setBadgeText({ text: String(current) });//提示透明度文字
16 }
17
18 chrome.tabs.executeScript(null, { code: "document.getElementById('testDom').style.opacity = " + parseInt(current) / 10 + ";" });//点击图标即时执行脚本调整透明度
19
20 current++;
21 if (current > max)
22 {
23 current = min;
24 }
25 }
26 chrome.browserAction.onClicked.addListener(updateIcon);//添加监听事件
27 chrome.extension.onRequest.addListener(function (request, sender, sendResponse)
28 {//返回请求数据
29 if (request.method == "getProfile")
30 {
31 var counter = request.number;
32 updateIcon(counter);
33 sendResponse({"test":"result"});
34 }
35 });

注:以上代码说明用,可能有错

配置页面

通常是设置用户保存的数据,有人用cookie,我比较喜欢用localstorage储存,反正不用考虑浏览器兼容问题等。

关于发布

chrome应用商店发布应用不收费已经是过去式,现在要想发布个插件得先拿5美刀好处费给谷歌,“此路是我开,此树是我栽,要想……”,谁让咱在人家的路上走呢,乖乖交钱才行。不过有个问题需要提醒一下:付账时候大陆是不能直接付款的,选择国家要选择中国香港,信用卡也不是全支持,我只知道用招行付款成功。发布了之后当然希望用户越来越多,但是发现推广这个活儿还真不会。

以下是我做的几个插件,同为码农的你也可能会有用,也顺便打个小广告;-)

第一个插件:“网页记单词

上网时间一多就有点后悔的感觉,然后就想把平时上网的时间用来背几个单词,找了很久没找到合适的插件,得,自己动手,于是乎第一个插件诞生。单击插件图标调整透明度,单词从屏幕上一条一条闪过,对鼠标设置了有影无形,不耽误操作,提供的单词表满足不了需要时还可以自己配置,英法德意日、提醒什么的各种东西随便塞。

第二个插件:“聚光灯

这是在完成第一个插件余温未散的情况下完成的,这个插件可以让用户专心致志读网页上的某一部分,用鼠标拾取dom,其余的用遮罩盖住,想看其他地方随便一点就能复原,还加了快捷键和视频高亮,在应用商店里有个“关灯看视频”用户已经达到了几十W!我发现我这个比他那个好用的多,但是不会推广,用户没几个……这个插件同时提供了中英文版本。

还能这样:

第三个插件:“屏蔽微博广告

昨天刚刚完成的一个。近段时间发现现在再上新浪微博没有以前舒心了,很喜欢的用户都特么在发各种广告、推荐关注,本来是来散散心,结果弄了个心烦意乱,一下午搞定,用起来还不错,对于广告微博的识别率还是相当高的。用上了就发现那几个“全球XXX”真恶心,各种广告,有的甚至全部都是,取消关注。

最后希望本文对你有用。

google chrome插件开发,自己动手,丰衣足食的更多相关文章

  1. Google Chrome插件开发-Context Menus

    本节主要介绍如何在Google Chrome浏览器web页面上点击右键弹出自定义菜单,即如何使用谷歌Context Menus API接口.上节已经把主要流程介绍了,这节就直接上代码,代码都是官方例子 ...

  2. Google Chrome 浏览器插件开发学习

    2014/11/16 Google Chrome 浏览器插件开发学习 因笔记存有文件,不便发表在cnblogs上,请到evernote里找笔记 "Google Chrome 浏览器插件开发学 ...

  3. [No000080]右键解锁增强Chrome插件开发,破除防复制

    昨天用360极速(虽然我不喜欢360.)浏览器,登陆知乎查阅一些东西,突然感觉有些观点很赞同,想copy转载一下,我了个去,它丫的居然不让我复制. 地址:https://www.zhihu.com/q ...

  4. chrome插件开发-消息机制中的bug与解决方案

    序言 最近开发chrome插件,涉及到消息传递机时按照教程去敲代码,结果总是不对.研究了大半天终于找到原因,现在记录下. 程序 插件程序参考官网 chrome官网之消息传递机制, 不能FQ的同事也可以 ...

  5. 如何查看google chrome 插件源码

    常用浏览器google chrome 有很多优秀的插件,寂寞的时候想看看人家是怎么实现的,说是快那就动手吧 插件代码位置 本人mac笔记本,chrome 插件位置如下 $ cd  /Users/vin ...

  6. Chrome插件开发,美化网页上的文件列表。chrome-extension,background

    上一篇文章 通过“content-scripts”的方式向页面注入js和css来美化页面,但是有一个弊端:一旦配置好需要注入的页面,之后如果这个页面地址以后发生变化,或者要新加一些URL进来,那么得修 ...

  7. Chrome插件开发,美化网页上的文件列表。chrome-extension,content-scripts

    趁着2018年还剩最后几天,发几篇博客,荒废太久了,惭愧. 最近也是需求驱动,研究了下Chrome插件开发.来看一下我们公司运维提供的日志查看页面 所有项目的日志都参杂在一起,每次去找都很痛苦.慢慢发 ...

  8. [Chrome插件开发]001.入门

    Chrome插件开发入门 Chrome扩展文件 Browser Actions(扩展图标) Page Actions(地址栏图标) popup弹出窗口 Background Pages后台页面 实战讲 ...

  9. 【Google Chrome】 Cross origin requests are only supported for protocol schemes: http, data, chrome, chrome-extension, https, chrome-extension-resource问题解决

    问题??打开Google Chrome浏览器报错如下: 结论  浏览器出于安全性考虑,默认对跨域访问禁止 解决方法  给浏览器添加启动参数 --allow-file-access-from-files ...

随机推荐

  1. Tomcat 8(九)解读Tomcat组件的生命周期(Lifecycle)

    Tomcat 8(七)解读Bootstrap介绍过.运行startup.bat.将引发Tomcat一连串组件的启动.事实上这一连串启动是通过组件的生命周期(Lifecycle)实现的 今天来看看Lif ...

  2. opencv-从图像旋转学习Mat数据訪问

    先看一个简单的样例 代码: // ConsoleApplication3_6_23.cpp : Defines the entry point for the console application. ...

  3. SQLServer------存储过程的使用

    转载: http://www.cnblogs.com/hoojo/archive/2011/07/19/2110862.html 例子: 1.学生表 CREATE TABLE [dbo].[Stude ...

  4. SQLServer------begin tran/commit tran事务的使用方法

    转载: http://www.cnblogs.com/accumulater/p/6089838.html 介绍 BEGIN TRAN 标记事务开始 COMMIT TRAN 提交事务 一般把DML语句 ...

  5. mybatis由浅入深day01_8输出映射_8.1resultType输出类型(8.1.1输出简单类型_8.1.2输出pojo对象和pojo列表_8.1.3输出hashmap)

    8 输出映射 8.1 resultType(输出类型) 使用resultType进行输出映射,只有查询出来的列名和pojo中的属性名一致,该列才可以映射成功. 如果查询出来的列名和pojo中的属性名全 ...

  6. /etc/docker/key.json

    /etc/docker/key.json 描述信息: This is the dockerd key for TLS connections.in web format, that docker us ...

  7. js二级联动

    <body> <section> <a>省份</a> <select id="province"> <option ...

  8. 演示PostgreSQL的详细安装及配置图解

    右击文件选择以管理员身份运行 2 开始执行程序的安装 3 设置安装目录 4 设置数据的保存目录 5 设置数据库管理员密码,请牢记此密码. 6 设置端口号,选择默认的端口号即可 7 根据自己选择设置地区 ...

  9. 详谈redis优化配置和redis.conf

    1. Redis.conf 配置参数: #是否作为守护进程运行 daemonize yes #如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid pidfile redi ...

  10. 预装的Office2016,文件图标表显示以及新建失败问题解决 方法

    新购买笔记本电脑,预装的office2016 学生版 启动激活后,会出现文件图标异常, 文件的类型为: ms-resource:Strings/FtaDisplayName.docx (.docx) ...