java 线程 插件_我的第一个Chrome插件:天气预报应用

1.Chrome插件开发基础

开发Chrome插件很简单,只要会基本的前台技术HTML、CSS、JS就可以开发了。

Chrome插件一般包括两个HTML页面background和popup。

background页面只在启动浏览器加载插件时载入一次,它不直接显示出来而是在后台运行。

它包含了插件的主要逻辑,收集或处理的结果可以保存到全局变量localStorage中传递给popup

页面。popup页面就是点击插件图标后弹出的页面,将用户需要的数据展示出来或者与用户交互。

此外插件还应该包含有CSS和JS文件以及一些图片文件。插件的相关配置都保存到一个叫做

manifest.json的文件中,里面的配置是以JSON数据格式保存的。

本文这个天气预报插件的源代码结构如下:

1336484981_5563.png

myplugin

|--bg.html

|--popup.html

|--manifest.json

|--img

|     |--icon.png

|--js

|     |--jquery-1.7.2.min.js

|--style

|--popup.css

2.实时获得天气预报信息

首先通过http://61.4.185.48:81/g/获得城市编号。注意,这个URL返回的是一个JS脚本,

其中变量id保存的是城市编号。之后通过http://m.weather.com.cn/data/[id].html获得

城市天气预报。这个URL返回的是JSON数据格式,如下:

{

"weatherinfo":

{

"city":"北京",

"city_en":"beijing",

"date_y":"2012年5月6日",

"date":"",

"week":"星期日",

"fchh":"08",

"cityid":"101010100",

"temp1":"31℃~19℃",

"temp2":"28℃~19℃",

"temp3":"29℃~18℃",

"temp4":"27℃~18℃",

"temp5":"23℃~14℃",

"temp6":"25℃~15℃",

"weather1":"晴转多云",

"weather2":"阴",

"weather3":"多云",

"weather4":"多云",

"weather5":"多云转阴",

"weather6":"阵雨转多云",

"img1":"0",

"img2":"1",

"img3":"2",

"img4":"99",

"img5":"1",

"img6":"99",

"img7":"1",

"img8":"99",

"img9":"1",

"img10":"2",

"img11":"3",

"img12":"1",

...

}

}

我们在bg.html中定时地获得到城市的天气信息,保存到全局变量localStorage中。

之后用户点击插件按钮时就可以通过popup.html看到实时的天气情况了。

3.jQuery基础

jQuery功能很多很强大,本文例子中主要用jQuery来简化Ajax调用,如getScript和get函数,

以及parseJSON函数将JSON字符串解析成JS对象,另外就是$("#id")对DOM对象的访问。

4.代码实现

具体实现起来还要注意几点:

一是localStorage不能直接保存解析好的JSON对象,因此bg.html要将字符串保存localStorage

中,popup.html自己解析后显示到页面上。

二是要在manifest.json中将天气网站配置到permission中,才可以在bg.html中跨域访问它。

manifest.json

{

"name": "My First Extension",

"version": "1.0",

"description": "The first extension that I made",

"permissions": ["tabs", "notifications","http://m.weather.com.cn/*"],

"background_page": "bg.html",

"browser_action": {

"default_icon": "img/icon.png",

"default_popup": "popup.html"

}

}

bg.html

weather

function init() {

//$id = "101070201";//此处是大连的城市ID,可以去weather.com.cn找到对应的weather city ID

//$url = "http://m.weather.com.cn/data/" + $id + ".html";//接口URL

// 利用下载服务器端脚本来间接解决跨域访问问题

$.getScript(

'http://61.4.185.48:81/g/',

function(){

$.get("http://m.weather.com.cn/data/" + id + ".html",

function(data) {

window.localStorage.weather = data;

}

);

}

);

}

window.setInterval("init()", 5*60*1000);

popup.html

weather

function init() {

var data = $.parseJSON(localStorage.weather);

var weatherinfo = data["weatherinfo"];

var datearray = ["", weatherinfo["date_y"], "第二天", "第三天", "第四天", "第五天", "第六天"];

$("#cityname").html(weatherinfo["city"] + "城市天气预报");

for (i = 1; i <= 6; i++) {

var divid = "#div" + i;

$(divid).append(datearray[i]).append("
");

var imgurl = "http://m.weather.com.cn/weather_img/" + weatherinfo["img"+(i*2-1)] + ".gif";

$(divid).append(''%20+%20imgurl%20+%20'').append("
");

$(divid).append(weatherinfo["temp" + i]).append("
");

$(divid).append(weatherinfo["weather" + i]);

}

}


popup.css

html {

height: 180px;

width: 700px;

}

#cityname {

text-align: center;

font-size: 20px;

font-weight: bold;

margin: 5px;

}

.weatherdiv {

float: left;

width: 15%;

margin: 5px;

}

5.调试\打包\安装

关于Chrome浏览器下开发的调试:

普通页面的调试:用console.log(obj);打印任意JS对象。之后在工具->JavaScript控制台进行调试。

插件开发的调试:打开活动视图bg.html。修改后,可以点击“重新载入”重新加载我们的插件。

1336485132_3361.png

在Chrome浏览器中,选择工具->扩展程序->开发模式->打包扩展程序

选择插件的根目录,打包后会产生压缩安装包crx和密钥文件pem。

1336485158_2780.png

安装方法很简单,直接把crx文件拖到chrome浏览器窗口里就可以了。

6.最终效果图

1336570523_2063.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/296281.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 时区设置

找到my.cnf或者my.ini [mysqld] default-time-zone8:00 转载于:https://www.cnblogs.com/lost-1987/articles/2799639.html

SQLite移植手记1

SQLite实现了大部分SQL92标准的SQL语句&#xff0c;同时支持ACID。还有其它许多特性这里不做深究&#xff0c;因为这在嵌入式领域来说应该是够用了。 下载&#xff1a;下载页面&#xff1a;http://www.sqlite.org/download.html我使用的还是当前最新版本&#xff1a;sqlite-3.3…

Dapr牵手.NET学习笔记:Actor一个场景

接上一篇最后的场景&#xff0c;为了解决相同帐户并发引起的数据库行级锁&#xff0c;可以引入Actor的串机制&#xff0c;相同ActorID的实例&#xff0c;串行&#xff0c;这样就能在应用层把读取余额的资源争抢解决掉&#xff0c;剩下的工作就是一定时间间隔&#xff0c;把内存…

【python】抄写大神的百度贴吧代码

原文链接&#xff1a;http://cuiqingcai.com/993.html 划重点&#xff1a; 1.提取帖子内容时&#xff0c;对图片&#xff0c;贴吧自动增加的超链接&#xff0c;制表符&#xff0c;换行符要做删除或替换处理 2.decode是把bytes转换为str, encode是把str转换为bytes 原帖中的代码…

敏捷开发组织【北京及其他地区QQ群】【长三角QQ群】【珠三角QQ群】

【北京及其他地区QQ群】http://qun.qq.com/#jointhegroup/gid/95849986 上限500人&#xff0c;创建日期2011-03-20&#xff0c;当前人数393&#xff0c;多数来自CSDN&#xff0c;包括北京约100人&#xff0c;长三角100人&#xff0c;珠三角100人&#xff0c;其他地区100人。未来…

保送北大,连发三篇Science,这位80后川妹子近日再发重磅级研究成果!

全世界只有3.14 % 的人关注了爆炸吧知识本文转自募格学术2020年9月21日&#xff0c;启函生物杨璐菡博士等在 Nature 子刊 Nature Biomedical Engineering杂志上发表了题为&#xff1a;Extensive germline genome engineering in pigs 的研究论文。杨璐菡杨璐菡带领的研究团队成…

TCP/IP 协议简单分析(建立连接握手过程)

原文&#xff1a;http://hi.baidu.com/wuguoyana/blog/item/38c04d3bcf047ce43a87ce55.html 首先TCP和IP是两种不同的协议&#xff0c;它们来七层网络模型中分别在不同的层次&#xff0c;IP协议是网络层的协议&#xff0c;TCP是更高一层的传输层的协议&#xff0c;TCP是建立在I…

java 继承接口语法_java的继承、接口方面的语法及知识

}父类的属性子类中都存在&#xff0c;只是有没有权限访问的问题根据名字找谁是谁&#xff1f;1.变量-> 类型 (类、接口)->接口2.已经确定是变量局部变量、形参->类的属性-> 外部类的属性就近原则构造方法&#xff1a;注意默认的那个无参构造方法优先调用父类的构造…

Linq 下的 Take() 方法内部机制是怎样的?

咨询区 Rahul Kishore&#xff1a;我的web需要访问数据库&#xff0c;但是表比较大&#xff0c;我仅仅想要获取该表中 N 条数据&#xff0c;我查阅了 MSDN 文档&#xff0c;看到了一个 Take() 方法&#xff0c;我现在很疑惑它的运行机制是下面哪一种&#xff1f;先从数据库中获…

【2】开发环境的搭建,Ubuntu14.04

这里使用的是Ubuntu14.04 Unity 更新源 首先&#xff0c;将更新源更换为国内更新源&#xff0c;我这里使用的是网易的更新源 sudo gedit /etc/apt/sources.list 1 deb http://mirrors.163.com/ubuntu/ trusty main restricted universe multiverse2 deb http://mirrors.163.com…

如何直接soap字符串,访问webservice

2019独角兽企业重金招聘Python工程师标准>>> 1.Webservice.GetVcardByUserNo(String userId&#xff0c;String userNo);这个是封装了的webservice接口。 2.在程序中连续两次调用该接口时&#xff0c;ksoap2在解析第二次调用返回的结果时抛异常。 异常信息如下&…

百度对301的反应

http://www.admin5.com/article/20111228/400200.shtml转载于:https://www.cnblogs.com/tonykan/archive/2012/12/04/2801449.html

《哈利波特》电影全集+有声书免费领取!带你重返儿时魔法世界……

全世界只有3.14 % 的人关注了爆炸吧知识说到哈利波特系列&#xff0c;几乎人人皆知&#xff0c;享誉世界&#xff0c;风靡全球的哈利波特究竟有什么无穷魔力呢&#xff1f;《哈利波特》是英国作家JK罗琳的魔幻文学系列小说&#xff0c;共7集&#xff0c;其中前六部以霍格沃茨魔…

.NET6下周发布真的香,可不少人却只会.NET Framework!

倒计时7天&#xff0c;.NET6VS2022C#10将同时发布正式版&#xff0c;宣告.NET步入全新篇章&#xff0c;各种新语法、新框架、新技术都如约而至&#xff0c;令人期待&#xff01;近年来&#xff0c;.NET跨平台持续推出新版本&#xff0c;开源社区也不断涌现各种优秀框架&#xf…

oracle 选择最频繁出现之前,5文章数据

SELECT* FROM(SELECTPROJECT_LISTING.MATERIAL,COUNT (*) AS "出现次数"FROMPROJECT_LISTINGWHEREPROJECT_LISTING.MATERIAL IS NOT NULLGROUP BYPROJECT_LISTING.MATERIALORDER BYCOUNT (*) DESC) WHERE ROWNUM < 5ORDER BYCOUNT (*) DESC 是关键排序COUNT (*)…

java 继承 子类 实例化_关于Java继承中父类和子类构造函数的问题

Java子类在实例化时默认调用的是父类的无参构造函数&#xff0c;不论实例化时调用的是子类的有参还是无参构造函数&#xff0c;1、当父类没有显式定义构造方法时&#xff0c;编辑器会默认为此类添加一个隐式无参构造函数。此时子类可以有自己的无参和有参构造方法。不论实例化时…

收缩临时表空间

当排序操作、重建索引等大型操作无法在内存中完成时&#xff0c;临时表空间将为排序提供便利。一般情况下临时表空间为多个用户&#xff0c;多个会话所共 享。不能为会话分批空间配额。临时表空间耗用过度且在不能自动扩展的情形下将收到“ORA-1652:unable to extend temp segm…

v4L2编程

v4L2编程 v4L2是针对uvc免驱usb设备的编程框架&#xff0c;主要用于采集usb摄像头等&#xff0c;编程模式如下&#xff1a; 一&#xff0e;设置采集方式 打开视频设备后&#xff0c;可以设置该视频设备的属性&#xff0c;例如裁剪、缩放等。这一步是可选的。在Linux编程中&…

java环境怎样搭建_如何学习JAVA?怎么搭建JAVA环境?怎么安装JDK?

JAVA在学习JAVA前&#xff0c;我们必须了解并搭建好JAVA所需的开发环境&#xff0c;要让你写代码能让机器听得懂并执行&#xff0c;JDK(Java Developers Kits)自然是是必须的安装JDK前的准备首先我们要先知道自己的电脑系统是几位版本的&#xff0c;右键”此电脑“点击菜单里的…

神奇的机械动态图,看了一遍又一遍!最后一个真神奇~

全世界只有3.14 % 的人关注了爆炸吧知识神奇的机械科技动态图&#xff0c;看了一遍又一遍&#xff01;最后一个真神奇&#xff5e;▲金属切割的慢镜头&#xff0c;美&#xff01;▲齿轮变速原理演示▲塑料成型机器▲切丝的食品机器▲螺旋状的通心粉制造▲高温融化锁的过程▲一次…