原生js实现查询天气的小应用
demo:https://zsqosos.github.io/weather/
截图:
实现功能:打开网页时显示用户所在城市的天气状况,在输入框输入城市可查询其它城市。
实现过程:先调用百度地图的API来获取用户所在的城市,随后调用聚合数据的天气API将数据放在页面上。由于ajax不支持跨域,所以采用了jsonp的方式来调用数据。
实现的原理比较简单,HTML和css比较长,我就只将js代码贴出来,想看完整代码的朋友可以去我的github查看 https://github.com/zsqosos/weather

//调用jsonp函数请求当前所在城市
jsonp('https://api.map.baidu.com/api?v=2.0&ak=Dv1NMU23dh1sGS9n2tUouDEYY96Dfzh3&s=1&callback=getCity');
window.onload=function(){
//请求天气车数据
btn.onclick=function (){
jsonp(createUrl());
}
};
function getCity(){
function city(result){
jsonp(createUrl(result.name));
}
var cityName = new BMap.LocalCity();
cityName.get(city);
}
// 数据请求函数
function jsonp(url){
var script = document.createElement('script');
script.src = url;
document.body.insertBefore(script, document.body.firstChild);
document.body.removeChild(script);
}
//数据请求成功回调函数,用于将获取到的数据放入页面相应位置
function getWeather(response) {
var oSpan = document.getElementsByClassName('info');
var data = response.result.data;
oSpan[0].innerHTML=data.realtime.city_name;
oSpan[1].innerHTML=data.realtime.date;
oSpan[2].innerHTML='星期'+data.weather[0].week;
oSpan[3].innerHTML=data.realtime.weather.info;
oSpan[4].innerHTML=data.realtime.weather.temperature+'℃';
oSpan[5].innerHTML=data.realtime.wind.direct;
oSpan[6].innerHTML=data.realtime.weather.humidity+'%';
oSpan[7].innerHTML=data.realtime.time;
oSpan[8].innerHTML=data.life.info.ziwaixian[0];
oSpan[9].innerHTML=data.life.info.xiche[0];
oSpan[10].innerHTML=data.life.info.kongtiao[0];
oSpan[11].innerHTML=data.life.info.chuanyi[0]; var aDiv = document.getElementsByClassName('future_box');
for(var i=0; i<aDiv.length; i++){
var aSpan = aDiv[i].getElementsByClassName('future_info');
aSpan[0].innerHTML = data.weather[i].date;
aSpan[1].innerHTML = '星期'+data.weather[i].week;
aSpan[2].innerHTML =data.weather[i].info.day[1];
aSpan[3].innerHTML = data.weather[i].info.day[2]+'℃';
}
changeImg(response);
}
//根据获取到的数据更改页面中相应的图片
function changeImg(data){
var firstImg = document.getElementsByTagName("img")[0];
var firstWeatherId=data.result.data.realtime.weather.img;
chooseImg(firstWeatherId,firstImg); var aImg = document.getElementById('future_container').getElementsByTagName('img');
for(var j=0; j<aImg.length; j++){
var weatherId = data.result.data.weather[j].info.day[0];
chooseImg(weatherId,aImg[j]);
}
}
//选择图片
function chooseImg(id,index){
switch(id){
case '0':
index.src='images/weather_icon/1.png';
break;
case '1':
index.src='images/weather_icon/2.png';
break;
case '2':
index.src='images/weather_icon/3.png';
break;
case '3':
case '7':
case '8':
index.src='images/weather_icon/4.png';
break;
case '6':
index.src='images/weather_icon/6.png';
break;
case '13':
case '14':
case '15':
case '16':
index.src='images/weather_icon/5.png';
break;
case '33':
index.src='images/weather_icon/7.png';
break;
default:
index.src='images/weather_icon/8.png';
}
}
//根据城市名创建请求数据及url
function createUrl(){
var cityName = '';
if(arguments.length == 0) {
cityName = document.getElementById('text').value;
}else{
cityName = arguments[0];
}
var url = 'https://op.juhe.cn/onebox/weather/query?cityname=' + encodeURI(cityName) + '&key=1053d001421b886dcecf81a38422a1a2&callback=getWeather';
return url;
}

一个简单的小demo,还有很多不足之处,欢迎大家提出改进建议。
明天我会更新一下在这其中遇到的一些问题以及解决方法,欢迎关注。
原生js实现查询天气的小应用的更多相关文章
- 一个简单用原生js实现的小游戏----FlappyBird
这是一个特别简单的用原生js实现的一个小鸟游戏,比较简单,适合新手练习 这是html结构 <!DOCTYPE html><html lang="en">&l ...
- 一个关于原生 js 开发一款插件的前端教程
教程链接: http://www.codeasily.net/course/plugin_course/ 写的不是很好,前面比较松后面比较急,请大家见谅,本人也没多少年前端经验,拿以前写过的教程网站, ...
- JQuery&原生js ——实现剪刀石头布小游戏
前言 jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库( 或JavaScript框架).jQuery设计的宗旨是“write L ...
- 原生js添加博客点击鼠标出小心心效果~~
昨天刚申请成功JS权限,心血来潮想添加点东西,记得之前看到别人家博客首页点击鼠标的时候会出现炫酷的 “小心心”,自己也来搞一个.没有用jquery啥的框架,原生js写起来麻烦了点,不过主要是怕博客首页 ...
- 原生JS实现的h5小游戏-植物大战僵尸
代码地址如下:http://www.demodashi.com/demo/12755.html 项目介绍 本项目是利用原生js实现的h5小游戏-植物大战僵尸,主要结合了一下自己对于h5小游戏的理解,结 ...
- 微信小程序结合原生JS实现电商模板(二)
接 <微信小程序结合原生JS实现电商模板(一)>,在首页列表加入购物车到购物和模块增删数量,动态计算商品价格实现后,本次提交主要实现了商品详情(还不完善)简单页面,从商品详情页跳转到购物车 ...
- js 小工具-- 原生 js 去除空格
// 原生js 去除字符串空格 <script type="text/javascript"> String.prototype.trim = function (){ ...
- 原生JS和jQuery分别使用jsonp来获取“当前天气信息”
需掌握的技能点: jsonp.跨域相关等. 以下两种代码,均可直接运行. 1.使用原生JS: <!DOCTYPE html> <html lang="en"> ...
- 用原生JS写一个网页版的2048小游戏(兼容移动端)
这个游戏JS部分全都是用原生JS代码写的,加有少量的CSS3动画,并简单的兼容了一下移动端. 先看一下在线的demo:https://yuan-yiming.github.io/2048-online ...
随机推荐
- 面向对象Part3
继承: Extends在英文中的翻译是拓展. 但是java允许多重继承. 一条线.单线. ------------------------------------------------------- ...
- leveldb 性能、使用场景评估
最近有个业务写远远大于读,读也集中在最近写入,这不很适合采用leveldb存储么,leveldb业界貌似ssdb用得挺广,花了两天时间就ssdb简单做下测试,以下总结. ssdb 是leveldb的r ...
- eclipse逐步调试
Eclipse 的单步调试 1.设置断点在程序里面放置一个断点,也就是双击需要放置断点的程序左边的栏目上.2.调试(1)点击"打开透视图"按钮,选择调试透视图,则打开调试透视图界面 ...
- 不得不说的wepapi 优化
1:在你的ASP.NET Web API中使用GZIP 或 Deflate .对于减少响应包的大小和响应速度,压缩是一种简单而有效的方式.这是一个非常有必要使用的功能,你可以查看更多关于压缩的文章在我 ...
- root切换
1.su -i root.password 2.su passwd root pass pass su pass 3.su -val 一般用户名 4.
- CocoaPods报错:The dependency `AFNetworking ` is not used in any concrete target 解决办法
产生这个问题的原因是最新版本的CocoaPods把Podfile文件的书写格式改变了,官网推荐用如下格式书写: platform :ios, '8.0' use_frameworks! target ...
- Python初识(一)
首先我有编程语言的基础,你也有就最好了,这样会很快认识Python. 当然由于本人见识和学识的局限性,请广大猿/媛们多多包涵与指正(希望多评论哦),共同进步嘛. ◆ 准备环境:到python官网下载p ...
- 在WinCC中通过VBS操作SQL Server2005
在项目中需要在一定条件满足时,保存一些数据到数据库中,并可根据条件查询.考虑到WinCC6.2以后采用的就是SQL Server2005数据库,所以直接利用该数据库即可,通过SQL Server Ma ...
- 初识c#
我记得我刚学c#的时候是在大一的下学期,那时候我在的学校是一个专科,因为我大一上学期学了c语言,对语言还蛮感兴趣,所以学的不错,在最后的考试是考的成绩还算可以,就考上了我们学校的教改班,那时候就是想好 ...
- 372. Super Pow
问题 Your task is to calculate ab mod 1337 where a is a positive integer and b is an extremely large p ...