谷歌浏览器插件开发

新手笔记,有建议,请告诉我

  1. 当前目录结构
  • 项目文件夹中:
    manifest.json #用于配置插件的权限和信息,以及对应文件的路径
    option.html #用于选项的配置页面,就是右击右上角插件显示选项的页面
    popup.html #用于画popup的页面,popup就是右上角点击插件后显示的页面
    devtools.html #devtiool的导航页面,没什么作用,但是一定要有
    devtool.html #用于画devtool的页面
    js文件夹
    css文件夹
    img文件夹
    fonts文件夹

  • js文件夹中:
    a.js #用于读取文档的js文件,权限也只能操作文档
    background.js #用于运行初始化的js,可以设置右键菜单,可以跨域请求
    dev.js #用于devtool页面配对的js文件
    devtools.js #用于配置devtool的页面
    pp.js #用于popup页面配对的js文件

  • img文件夹中:
    png.png #用于插件的图片,暂时发现必须是png格式

  • 其他使用的css框架放入对应文件夹即可,当前使用bootstrap框架
  1. manifest.json
{
  "name": "测试工具",
  "manifest_version": 2,
  "version": "0.0.1",
  "description": "一切为了测试",
  "icons":
    {
        "16": "img/png.png",
        "48": "img/png.png",
        "128": "img/png.png"
    },
  "browser_action": {
    "default_icon": "img/png.png",
    "default_title": "这是一个Chrome插件,一起为了测试",
    "default_popup": "popup.html"
  },
  "content_scripts": [
    {
      "matches": ["<all_urls>"],
      "js": ["js/a.js"]
    }
  ],
  "background":
    {
        
        "scripts": ["js/background.js"]
    },
    "options_page": "option.html",
    
    "options_ui":
    {
        "page": "option.html",
        
        "chrome_style": true
    },
  "homepage_url": "https://www.baidu.com",
  "devtools_page": "devtools.html",
  "permissions":
    [
        "contextMenus", 
        "tabs", 
        "notifications", 
        "webRequest", 
        "webRequestBlocking",
        "storage", 
        "http://*/*", 
        "https://*/*" 
    ]
}
  1. 画页面
    页面只是纯的html代码,如果使用onclick之类触发js的方法,这里的会报错,需要在js绑定操作
radio 的方式:获得:$('input[type=radio][name=addr]').change(function () {this.value}),赋值:$('input[type=radio][value=' + items.ele + ']')[0].checked = true 
勾选框的方式:获得: $('#num1').change(function () {this.checked}) ,赋值:$('#num1')[0].checked = items.num
输入框的方式: 获得:$('#f1').change(function () {this.value }) ,赋值:$('#f1')[0].value = items.f
select的方式: 获得:$('#addr').change(function () {this.options[this.selectedIndex].value}) ,赋值:$("#addr").val(items.addr)
  1. 存储值
    除了浏览器的localStorage等存储信息,还有插件特有的功能:
$('#addr').change(function () {
    chrome.storage.sync.set({ addr: this.options[this.selectedIndex].value }, function () {
        chrome.storage.sync.get({ addr: '310000' }, function (items) {
            console.log(items.addr);
        });
    });
});
#此处存的值不能大于4K,不然会报错
  1. 通信和调用
    background.js 通知 context(a.js) 使用sendmessage的通信:
#background.js 发送信息,使用:
function sendMessageToContentScript(message, callback) {
  chrome.tabs.query({ active: true, currentWindow: true }, function (tabs) {
    chrome.tabs.sendMessage(tabs[0].id, message, function (response) {
      if (callback) callback(response);
    });
  });
}

# a.js中接受信息,使用:
  chrome.runtime.onMessage.addListener(function(request, sender, sendResponse)
{})
#其中当刷新组件代码后,还需要刷新测试页面,保证通信一致

在dev.js中调用background.js 中的方式:

chrome.extension.getBackgroundPage().xxxx方法;

在a.js,通知background.js:

#a.js中:
chrome.runtime.sendMessage({ cmd: 'c', value: v }, function(response) {
          console.log('收到来自后台的回复:' + response);
        });

#background.js中:
chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) {
sendResponse(xxxx)
return true;
#这里的返回必须添加,不然总是报错
})
  1. 右键菜单设置
chrome.contextMenus.create({ "id": "main", "visible": true, "title": "xxx", contexts: ['editable'], onclick: shenfenzheng })

其中的contexts当为normal时,可以显示多级菜单,不然只能显示一级

  1. 运行方式
    1,谷歌浏览器或者谷歌内核的浏览器选择扩展程序、或者应用中心等管理插件的地方
    2,打开开发者模式
    3,加载已解压的扩展程序,指定到项目目录,即可
    其他方式,打包扩展程序,指定到项目目录,打包,生成pem文件和crx文件。可以把crx上传到谷歌的应用商店,不过需要5美元;或者把crx格式改成zip格式,给他人后,拖拽进入开发者模式的插件管理页面。

  2. 样例地址:
    https://gitee.com/tuboyou/ChromeExtraTool4Test

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,539评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,594评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,871评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,963评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,984评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,763评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,468评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,850评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,002评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,144评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,823评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,483评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,026评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,150评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,415评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,092评论 2 355