--chrome交互式插件的各个部分

Chrome插件的基础知识就不多说了。随便找个新手教程就能够上手了,比如官方提供的Overview与Getting Started教程足够入门了;笔者也是现学现卖。

一个插件事实上就是一些常见web资源的集合,将诸如js脚本、css样式、html文本、图片甚至dll等资源打包到一个文件里,并配上一个说明文档manifest.json,来说明插件须要的权限以及各个资源之间的一些基本的关系。插件安装到浏览器之后,能够在一定程度上控制浏览器的行为,相同也能够控制浏览器中显示的web页面的dom。而使用了dll之后。插件能做的事就很多其它了。能够提供超越浏览器范畴的功能。出于安全考虑,Google官方已经在限制dll的使用。

插件中代码的划分

Chrome插件的代码大致分为三部分:

  1. background page(背景页面):大多插件包含一个不可见的背景页面,用于维持整个插件的主要逻辑。
  2. UI页面:一个插件还能够包含一些UI页面。包含弹出页面(在点击插件图标时弹出)、配置页面(配置插件时打开)以及覆盖页面(一个插件能够覆盖“书签管理页”、“历史页”或“新建标签页”三者之中的一个)。
  3. content script(内容脚本):假设插件须要跟web页面进行交互。插件就须要使用内容脚本。

插件的一个强大之处在于其与web页面交互的能力,这样的能力是通过内容脚本与页面DOM的交互来完毕的。

有了插件。一个页面的dom能够被页面本身的javascript脚本以及随意的内容脚本共享。这些脚本都能够改动页面的dom,而且全部的脚本都能够马上感知到变化,可是为了鲁棒性的考虑,web页面的脚本与内容脚本应该是互相孤立的。

各脚本执行在自己的“isolated world(隔离世界)”中,各自包括纯净的JavaScript环境。确保相互之间不相影响

多个“隔离世界”能够共享同一个DOM树。但却分别拥有自己相应的JavaScript实现对象。

比如,web页面能够使用jQuery1.11版本号。而我们的内容脚本能够使用jQuery2.0版本号,而两者的使用互不影响。同一时候。由于插件可能拥有特权API以及用户敏感信息的訪问权限,我们须要确认web页面的脚本无法共享这些权限。由于“隔绝世界”之间不共享JavaScript对象,因此web页面的脚本不可能通过共享的DOM去打破正常的页面沙盒,来訪问内容脚本或者插件的 API。

各部分代码的交互

插件能够通过内容脚本或跨域的Ajax请求来与页面或远端服务交互。

插件中的各页面(包含背景页面)能够互相訪问各自的DOM。也能够调用各自己定义的函数。我们须要做的就是调用chrome.extension的 getViews()或getBackgroundPage()找到相应的页面,然后就能够调用其函数和操纵其DOM了。

比如我们在背景页面脚本background.js中定义了一些公用函数,如日期格式化函数:

         // (newDate()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-0208:09:04.423// (new Date()).Format("yyyy-M-dh:m:s.S") ==> 2006-7-28:9:4.18Date.prototype.Format = function(fmt) {var o = {"M+" : this.getMonth()+1, //月份"d+" : this.getDate(), //日"h+" : this.getHours(), //小时"m+" : this.getMinutes(), //分"s+" : this.getSeconds(), //秒"q+" : Math.floor((this.getMonth()+3)/3), //季度"S" :this.getMilliseconds() //毫秒};if(/(y+)/.test(fmt))fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 -RegExp.$1.length));for(var k in o)if(new RegExp("("+ k+")").test(fmt))fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ?

(o[k]) :(("00"+ o[k]).substr((""+ o[k]).length))); return fmt; }

在弹出框的初始化脚本initPopup.js中。我们能够这样重用代码:

var bg =chrome.extension.getBackgroundPage();
Date.prototype.Format= bg.Date.prototype.Format;

内容脚本能够看作是web页面的一部分。而非插件的一部分;因此内容脚本能够改动web页面的dom,却不能够改动背景页面的dom,即不能调用getBackgroundPage等特权方法。

值得注意的是:

  • 内容脚本与web页面执行在不同的沙盒中的。两者的JS方法之间不能够相互调用。
  • 内容脚本与插件的其它部分是能够间接交互的,这一交互通过消息的收发来完毕。


消息传递

基于安全考虑,内容脚本的JavaScript环境是没有特权的。就像他影响的web页面一样。

这就意味着,假设你想要从内容脚本中訪问插件API,就必定须要一种在内容脚本与插件的特权部分进行通讯的方式,这样的方式就是“message passing(消息传递)”了。“消息传递”同意插件的各部分之间进行通讯。通常我们会希望内容脚本和背景页面之间进行通信,只是插件的随意页面之间都能够进行通讯。假设知道了其他插件的唯一ID。我们甚至能够向其他的插件发送消息。

这里举个简单的样例:

弹出框的初始化脚本中包括一个saveParam方法。负责获取弹出框中的两个值,然后存储到浏览器的同步storage中。

然后给id为btn的button设置单击事件处理函数。调用保存方法,并向插件的其它部分发送消息:

         functionsaveParam(){_d = $('#aidForm#zcrq').val(), _hqhw = $('#aidForm #hqhw').val();chrome.storage.sync.set({'zcrq':_d,'hqhw':_hqhw});}function getSavedParam(callBack){chrome.storage.sync.get(function(o){_d = o.zcrq, _hqhw =o.hqhw;if(null !=callBack){callBack();}});}$('#aidForm #btn').click(function(e){saveParam();chrome.extension.sendRequest({'msg':'openpage','zcrq':_d, 'hqhw':_hqhw,'url':'xxxxxx'},function(data) {});e.preventDefault();});

然后在背景页面脚本或内容脚本中,我们能够注冊消息监听方法。来依据消息内容进行对应的处理:

         chrome.extension.onRequest.addListener(function(request,sender, sendResponse){if(request.msg== 'openpage'){_d= request.zcrq, _hqhw = request.hqhw;chrome.tabs.create({'url':request.url,'active':true});}});

因为内容脚本仅仅能调用chrome.extension对象中的一部分特权方法,上例中的chrome.tabs对象的特权方法即不能调用;可是内容脚本能够通过消息传递机制,发送消息给插件的其他部分,如背景页面脚本,让后者帮助其完毕部分工作。当然,有兴趣的话,插件其他部分的代码还能够使用HTML5的window.postMessage方法,配合window.addEventListener方法来进行消息的传递。

最佳实践

综上文所述,chrome插件开发的最佳实践可能是:

背景页面脚本负责维护插件的主要逻辑及方法,内容脚本负责与web页面进行直接的交互,弹出框和选项等页面作为辅助,内容脚本与插件的其他脚本之间通过消息传递机制进行交互。进而达到插件各个部分功能的融合。

That’s all! 希望能帮到大家。

另:文中一段有标了删除线的两个词“孤立”、“影响”原来各自是“duli”和“chongtu”,发表的时候竟然提示“* 对不起,文章中包括敏感词,请您检查再公布。

”。保存不成功,耽误了文章的发表,汗颜。汗颜,汗颜!

!心中奔腾着一万匹羊驼!

版权声明:本文博客原创文章,博客,未经同意,不得转载。

转载于:https://www.cnblogs.com/bhlsheji/p/4744165.html

记得12306货运系统“抢购空”编写插件--chrome交互式插件的各个部分相关推荐

  1. chrome浏览器插件SwitchyOmega的安装(离线安装)

    一.说明 SwitchyOmega为CHROME的一款http代理配置插件 chrome的插件的安装方式有多种类,熟悉的可以直接百度, 这是一篇比较全面的说明文档:http://www.cnplugi ...

  2. 浅谈C#中一种类插件系统编写的简单方法(插件间、插件宿主间本身不需要通信)...

    文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/. 1.背景 三年多前还在上研时,用C#+反射机制写过插件系统,后来又用M ...

  3. 在Qt中如何编写插件,加载插件和卸载插件

    Qt提供了一个类QPluginLoader来加载静态库和动态库,在Qt中,Qt把动态库和静态库都看成是一个插件,使用QPluginLoader来加载和卸载这些库.由于在开发项目的过程中,要开发一套插件 ...

  4. 编写LitmusRT调度器插件

    目录 背景 打桩 编译安装 引入TRACE模块来输出debug信息 为P-EDF定义每个CPU的状态 激活插件 模块测试 添加调度逻辑 帮助函数 demo_job_completion() demo_ ...

  5. 不反编译、无逆向基础也能轻松编写Android App Hook插件? Xposed的远房表弟,Hookworm来也!

    前言 Xposed的大名相信很多同学都不陌生,它提供了一种能力,可以在不修改原apk的情况下,以插件的方式改变目标App的某些行为. 但随着Android系统版本的迭代,原来的Xposed已经不适合在 ...

  6. [Linux实用工具]munin-node插件配置和插件编写

    前面介绍了2篇munin使用的相关文章: [Linux实用工具]Linux监控工具munin的安装和配置 [Linux实用工具]Linux监控工具munin的展示(Nginx) 这次介绍一下munin ...

  7. [置顶]       编写自己的JQUERY插件

    如何编写自己的jquery插件 Jquery的插件主要分为三类: 1.封装对象方法的插件:大部分插件都是封装对象的插件 2.封装全局函数的插件:将独立的函数添加到jquery的命名空间之下.Jquer ...

  8. 使用 jQuery UI Widget Factory 编写有状态的插件(Stateful Plugins)

    使用 jQuery UI Widget Factory 编写有状态的插件(Stateful Plugins) 使用 jQuery UI Widget Factory 编写有状态的插件(Stateful ...

  9. (原创)面向对象的系统对接接口编写。第4篇

    接上一篇:http://www.cnblogs.com/mazhiyuan/p/5224050.html 这篇开始写Post和Get请求的布局. 我们就以新闻模块来举例吧.其它的模块,比如用户啦,比如 ...

  10. mysql 半同步 插件_编写半同步复制插件

    编写半同步复制插件 本节介绍如何使用plugin/semisyncMySQL源代码分发目录中的示例插件编写服务器端半同步复制插件.该目录包含名为rpl_semi_sync_master和的主插件和从插 ...

最新文章

  1. div滚动到指定位置 vue_【Vue 进阶】从 slot 到无渲染组件
  2. editor 插入图片之后将光标放到右侧_通过vscode插件自动上传剪贴板图片至aws s3
  3. 快学Scala习题解答—第十章 特质
  4. 使用iframe+postMessage跨域操作和通信
  5. 第7章 实战演练:爬取百度百科1000个页
  6. oracle服务开机自启动
  7. Com/ATL编程 一些学习链接
  8. jQuery 设计和自定义一个带展开动画效果的导航栏
  9. 在nhibernate 1.2 中使用sqlite时应注意sqlite的ado.net的提供者 .
  10. 使用原生javaScript创建ul和li对象以及操作
  11. 【图像配准】基于matlab GUI光流场模型图像配准【含Matlab源码 831期】
  12. 如何制作通讯录vcf_批量信息从表格导入手机“通讯录”
  13. 常用的正则表达式大全(数字、字符、固定格式)
  14. 中国行政区域划分 爬虫工具
  15. 计算机修改桌面图标大小,windows更改桌面图标大小设置
  16. win7蓝屏报错:STOP:0x0000007E
  17. 程序员职业生涯系列:关于技术能力的思考与总结
  18. 计算机屏幕截图按什么键,电脑上截图按哪个键_电脑截图快捷键是什么
  19. 计算机英语 book,book是什么意思_book在线翻译_英语_读音_用法_例句_海词词典
  20. 胃不好吃什么养胃 三九胃泰提示常吃芝麻更护胃

热门文章

  1. topgate镜像_AMOLED电流镜像像素电路的稳定性分析
  2. 分布式任务调度平台201902
  3. HTML网页设计制作——响应式网页影视动漫资讯bootstrap网页(9页)
  4. Codeforces Problem-705A Hulk
  5. 【田间连着车间、佘太酒业这十年!
  6. android killer 反编译工具,安卓反编译工具-Android Killer下载1.3.0.0 正式版-腾牛下载...
  7. matlab的f检验和t检验,统计学在数学建模中的T检验和F检验
  8. Angluar编译过程中出现的TS2339问题
  9. 商城APP开发关键板块
  10. 小蚂蚁学cURL笔记(1)