Chrome浏览器扩展开发系列之十九:扩展开发示例

翻译总结了这么多的官网内容,下面以一款博主开发的“沪深股票价格变化实时追踪提醒”软件为例,介绍Chrome浏览器扩展程序的开发,开发环境为Eclipse IDE+Chrome Browser。

“沪深股票价格变化实时追踪提醒”软件能够实时获取用户指定的股票的价格等参数,并根据用户设置的价格区间进行越界提醒。该软件目前只实现了两部分,一个是options页面,用以配置用户要监听的股票及股票的价格区间。另一个是browser action类型的popup页面,供用户查看股票当前价格,并通过图标的Badge实现价格越界提醒。

首先在Eclipse中创建JavaScript项目。

在JavaScript项目所在的目录下分别创建_locales、css、html、img和js子目录,并创建manifest.json文件。

在_locales目录下创建zh_CN子目录,在zh_CN子目录下创建messages.json文件,支持中文的国际化。

将必要的CSS文件复制到css目录下。

将必要的PNG文件复制到img目录下。

在html目录下创建options.html和popup.html文件。HTML页面非常简单,只给出了HTML基本元素结构,引入了必要的CSS和JS。页面的具体内容都是由JS根据读取的数据动态生成的。

在js目录下创建如下JS文件:

  • constants.js定义全局常量
  • background.js定义数据操作逻辑,包括启动时的初始化和运行时的读写逻辑
  • storage.js定义数据存储逻辑,通过chrome.storage.sync API实现持久化数据的真正读写
  • options.js定义options.html页面的内容
  • popup.js定义popup.html页面的内容
  • utils.js定义通用的JS函数
  • jquery-min.js第三方jQuery类库

manifest.json文件内容:

 1 {
 2   "manifest_version": 2,
 3
 4   "name": "__MSG_extension_name__",
 5   "description": "__MSG_extension_description__",
 6   "version": "1.0",
 7
 8   "default_locale": "zh_CN",
 9
10   "content_security_policy": "script-src ‘self‘ ‘unsafe-eval‘; object-src ‘self‘",
11
12   "background": {
13     "scripts": ["js/shanghaiA.js", "js/shanghaiB.js", "js/shenzhenA.js", "js/shenzhenB.js", "js/shenzhenC.js", "js/shenzhenJ.js", "js/constants.js", "js/utils.js", "js/background.js", "js/storage.js"],
14     "persistent": true
15   },
16
17   "permissions": [
18       "notifications",
19       "storage",
20     "<all_urls>"//由于要通过Web Services调用获取股票的实时信息,此处必须有此项
21   ],
22
23   "options_page": "html/options.html",
24   "options_ui": {
25     "page": "html/options.html",
26     "chrome_style": true,
27     "open_in_tab": false
28   },
29
30   "browser_action": {
31     "default_icon": {
32         "38": "img/vos128.png",
33         "19": "img/vos48.png"
34     },
35     "default_title": "__MSG_extension_browser_action_default_title__",
36     "default_popup": "html/popup.html"
37   }
38 }

数据结构:

 1 //object name saved in chrome storage
 2
 3 var VOG_LOG = "VOSTOCK";
 4
 5 //object data saved in chrome storage
 6
 7 var VOG_LOG_DATA = {
 8
 9        dataVersion: 3,      //当前版本
10
11        products: [],        //用户监听的股票,用户可以通过options页面配置,其中包括股票的基本信息和用户的期望范围
12
13        interval: 5,         //股票信息更新时间间隔,默认5秒
14
15        notification: false  //是否开通Notification通知,默认不开通
16
17 };

options页面示例:

popup页面示例:

上图中,提示股票价格达到了期望上限。

关于Chrome浏览器扩展的介绍就此告一段落,谢谢大家的关注。

下面将陆续结合笔者目前的实际工作,陆续发布与Chrome浏览器Native Client相关的开发文档,希望能够继续得到大家的关注。

时间: 2024-12-24 11:31:29

Chrome浏览器扩展开发系列之十九:扩展开发示例的相关文章

BizTalk 开发系列(三十九) BizTalk Server 2009技术概览

BizTalk Server 2009已经发布一段时间了,之前Beta版发布的时候也写过一篇文章<BizTalk Server 2009 Beta初体验>, 当时比较了2006 R2与2009 Beta这两个版本之间的常见功能的开发.发现表现平平,没有什么太让人兴奋的地方.随着最近一段时间BizTalk Server 2009配套产品(组件)的陆续发布.对于新一代的BizTalk开发应用平台的认可逐渐清晰起来. BizTalk新一代的开发与应用平台除了操作系统.数据库及集成开发环境之外主要包括

Android开发系列(十九):为SimpleAdapter设置样式

Adapter的作用:数据在adapter中做了处理之后,显示在视图上 一般的对于ArrayAdapter来说,只需要把一个数组和一个样式传递给ArrayAdapter之后就可以在视图上用一个列表显示出这个字符串数组. 例如下边的代码: listView.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,ls)); 但是,比如我们手机的联系人目录所示,不仅仅是有列表,而且有头像,可能还有手机

Chrome浏览器扩展开发系列之十四:本地消息机制Native messagin

Chrome浏览器扩展开发系列之十四:本地消息机制Native messaging 2016-11-24 09:36 114人阅读 评论(0) 收藏 举报  分类: PPAPI(27)  通过将浏览器所在客户端的本地应用注册为Chrome浏览器扩展的"本地消息主机(native messaging host)",Chrome浏览器扩展还可以与客户端本地应用之间收发消息. 客户端的本地应用注册为Chrome浏览器扩展的"本地消息主机"之后,Chrome浏览器会在独立的

Chrome浏览器扩展开发系列之十四

Chrome浏览器扩展开发系列之十四:本地消息机制Native messaging 时间:2015-10-08 16:17:59      阅读:1361      评论:0      收藏:0      [点我收藏+] 通过将浏览器所在客户端的本地应用注册为Chrome浏览器扩展的"本地消息主机(native messaging host)",Chrome浏览器扩展还可以与客户端本地应用之间收发消息. 客户端的本地应用注册为Chrome浏览器扩展的"本地消息主机"

QT开发(四十九)——数据库用户接口层

QT开发(四十九)--数据库用户接口层 用户接口层主要包括Qt SQL模块中的QSqlQueryModel.QSqlTableModel.QSqlRelationalTableModel.用户接口层的类实现了将数据库中的数据链接到窗口部件上,是使用模型/视图框架实现的,是更高层次的抽象,即便不熟悉SQL也可以操作数据库.需要注意的是,在使用用户接口层的类之前必须先实例化QCoreApplication对象. QT中使用了自己的机制来避免使用SQL语句,提供了更简单的数据库操作及数据显示模型,分别

QT开发(二十九)——QT常用类(三)

QT开发(二十九)--QT常用类(三) 一.QImage 1.QImage简介 QT中提供了四个处理图像数据的类:QImage.QPixmap.QBitmap.QPicture. QImage提供了允许直接访问像素数据的硬件无关的图像显示方案,能够用作绘图设备. QImage专门为I/O.直接像素访问操作而设计,并进行了优化.访问图片的像素或是修改图片像素,则需要使用QImage,或者借助于QPainter来操作像素. 由于QImage继承自QPaintDevice,QPainter可以直接在Q

QT开发(三十九)——GraphicsView框架

QT开发(三十九)--GraphicsView框架 本文主要翻译自QT 5.6.2GraphicsView官方文档 一.GraphicsView框架简介 QT4.2开始引入了Graphics View框架用来取代QT3中的Canvas模块,并作出了改进,Graphics View框架实现了模型-视图结构的图形管理,能对大量图元进行管理,支持碰撞检测,坐标变换和图元组等多种方便的功能. GraphicsView框架结构主要包含三个主要的类QGraphicsScene(场景).QGraphicsVi

C++语言笔记系列之十九——虚函数(2)

1.构造函数和析构函数中调用虚函数 (1)采用静态编译. (2)在编译阶段自动联接自己类中的函数或基类中的函数,不在派生类中重定义一个函数. 注:构造函数和析构函数中调用的虚函数,派生类都不一定存在的情况下,只能去调用基类或者自身的函数. example 1 #include <iostream.h> class A { public: A() {} virtual void func() {cout<<"A construction."<<endl

Python开发【第十九篇】:Python操作MySQL

Python开发[第十九篇]:Python操作MySQL 本篇对于Python操作MySQL主要使用两种方式: 原生模块 pymsql ORM框架 SQLAchemy pymsql pymsql是Python中操作MySQL的模块,其使用方法和MySQLdb几乎相同. 下载安装 ? 1 pip3 install pymysql 使用操作 1.执行SQL + ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26