chrome系列-扩展程序开发学习-可配置选项

chrome系列-扩展程序开发学习-可配置选项

月光魔力鸭

2018-09-10 09:16 阅读 234 喜欢 0 chrome系列 可选配置

接下来,我们综合上面的配置,再加一个选项页面配置,做一个天气预报的小栗子。

栗子:天气预报:

主要是使用options_page参数,增加配置页面。

manifest.json
{
    "manifest_version":2,
    "name":"天气预报",
    "version":"1.0",
    "description":"获取天气预报,同时可以配置不同地区的获取",
    "icons":{
        "16":"img/icon16.png"
    },
    "browser_action":{
        "default_icon":{
            "16":"img/icon16.png"
        },
        "default_title":"天气预报",
        "default_popup":"popup.html"
    },
    "options_page":"options.html",
    "permissions":[
        "https://free-api.heweather.com/s6/weather/now?*"
    ]
}

栗子里面使用的API是和风天气,注册下就可以免费使用。

根据上面我们的json配置,需要有两个页面: options.html popup.html.

options.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>设定城市</title>
</head>
<body>
    <input type="text" name="city" id="city" placeholder="请输入您所在的城市,默认泰安">
    <input type="button" id="save" value="保存">
</body>
</html>
<script type="text/javascript" src="options.js"></script>

options.js

var city = document.getElementById('city');

var save = document.getElementById('save');

var value = localStorage.city || '泰安';

city.value = value;

save.onclick = function(){
    localStorage.city = city.value;
    alert('保存成功');
}

我们默认使用一个地址,然后将用户提交的地址,保存在localStorage中。

popup.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>天气</title>
    <style>
        #tianqi{
            min-width:200px;
            min-height:50px;
        }
    </style>
</head>
<body>
    <div id="tianqi">

    </div>
</body>
</html>
<script type="text/javascript" src="popup.js"></script>

popup.js

var request = function(url,cb){
    var xhr = new XMLHttpRequest();
    xhr.open('GET',url);
    xhr.onreadystatechange = function(){
        if(xhr.readyState ==4 && xhr.status == 200){
            cb(xhr.responseText);
        }
    }
    xhr.send();
}

var url = 'https://free-api.heweather.com/s6/weather/now';
var city = localStorage.city || '泰安';
var key = '注册后的KEY';
url = url + '?location='+city+'&key='+key;
request(url,function( res ){
    var tianqi = document.getElementById('tianqi');
    var obj = JSON.parse(res);
    console.log(obj);
    obj = obj.HeWeather6[0];
    var html = '当前地区:'+obj.basic.location+',天气:'+obj.now.cond_txt+',风向:'+obj.now.wind_dir;
    tianqi.innerHTML = html;
});
看效果

效果图

转载请注明出处: https://chrunlee.cn/article/chrome-learn-5.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
需求:可能会有在页面加载的时候想执行某个js,例如统计页面的DOM等等。
昨天客户发现了个小BUG,文章发布使用的ueditor, 上传视频的时候当时好好的,后来怎么就是播放不了?
最近有系统需要知道性能瓶颈,尝试使用jmeter对重要接口进行并发测试,确定能否支撑一定的用户数量。
之前看知乎相中了一个想法,给宝宝做一个站,上传生活的日常照片啊、视频之类的,存储肯定是在自己家里,然后做个穿透这样..开始做的时候又想着是时候接触下这些东西了,虽然公司都一点不用,但是自己没事接触下拓展下也是好的。
写到这里,基本上就完成了我之前一篇文章中写的,我要做一个自己的图床的小程序了。在最初我要做图床的时候,发现在谷歌扩展程序上一无所知,所以才开始学习的这个,到这一步,至少能勉强能跑通自己的小程序了。
一直有跑着puppeteer在做pdf的生成,可以今天突然发现一个问题:预览与打印生成的PDF不一致,猜测可能是边距导致的,应该是没设置好... 然后当我在本地尝试的时候也发现了这个问题..要么是字符,要么是版本
之前做了一段时间的上传相关的断点续传和秒传功能,这里整理下大体思路
上一张中已经完成了比较简易的3D全景浏览,但是...这是写死在xml中的,对于我们实际的项目,这种情况是不可能适应的。所以,来了解下如何动态加载xml已经设置对应的热点。