js获取本地地址及天气的几种方式
来源:互联网 发布:des算法实例 编辑:程序博客网 时间:2024/05/22 01:25
一、获取本地的地址
第一种方式:
1、利用浏览器获取当前位置的经纬度
window.onload=getCurrentPosition;//浏览器获取当前位置function getCurrentPosition() { if (window.navigator.geolocation) { var options = { enableHighAccuracy: true, }; window.navigator.geolocation.getCurrentPosition(handleSuccess, handleError, options); }else { alert("浏览器不支持html5来获取地理位置信息"); }}
2、浏览器获取到的是GPS坐标,需要转换成城市名称再通过城市获取天气:
//成功获取时调用的函数function handleSuccess(position) { // 获取到当前位置经纬度 本例中获取到的是gps坐标系 //经度 var lng = position.coords.longitude; //纬度 var lat = position.coords.latitude; //转换成百度坐标系 //将请求发送给‘ var ggPoint = new BMap.Point(lng, lat); //地图初始化 var bm = new BMap.Map(); //坐标转换完之后的回调函数 translateCallback = function (data) { if (data.status === 0) {//回调成功 var marker = new BMap.Marker(data.points[0]); var myGeo = new BMap.Geocoder(); var baiduPoint = new BMap.Point(data.points[0].lng, data.points[0].lat); //将经纬度转换成城市 myGeo.getLocation(baiduPoint, getCityByCoordinate); } } setTimeout(function () { var convertor = new BMap.Convertor(); var pointArr = []; pointArr.push(ggPoint); convertor.translate(pointArr, 3, 5, translateCallback) }, 2000);}function getCityByCoordinate(result) { var gpsAadress=result.addressComponents; var city=gpsAadress.city; //将转换之后的城市传入获取天气的函数做参数 getWeatherDatas(city); return city;}function handleError() { log('地点定位出错');}
第二种方式:
1、利用百度API通过IP地址获取本地地址
//通过百度的 IP地址获取本地地址window.onload=getCurrentPosit; function getCurrentPosit() { var map = new BMap.Map('getCity'); function myFun(result){ var cityName = result.name; getWeatherDatasFun(cityName); map.setCenter(cityName); alert("当前定位城市:"+cityName); } var myCity = new BMap.LocalCity(); myCity.get(myFun);
二、通过城市获取天气数据:
function getWeatherDatas(city) { var url='http://route.showapi.com/9-2?'; if(city===undefined || city===""){ log('您还未输入') }else { $.ajax({ type: 'post', url: url, dataType: 'jsonp', data: { "showapi_timestamp": new Date().getTime(), "showapi_appid": '44277', //这里需要改成自己的appid "showapi_sign": '9987d6dff19e482488b33dc8ed70f6e9', //这里需要改成自己的应用的密钥secret, "area":city }, jsonp: 'jsonpcallback', //这个方法名很重要,不能改变 error: function(XmlHttpRequest, textStatus, errorThrown) { log("操作失败,请重试!"+errorThrown); }, success: function(result) { //解析获取到的天气数据 console.log('The Weather datas: ',result); } }); }}
阅读全文
0 0
- js获取本地地址及天气的几种方式
- 调用百度apiStore的天气 自动获取地址 及本地天气
- js获取本地地址
- 获取本地IP几种方式
- JS获取URL地址的几种方法
- JS获取几种URL地址的方法
- JS获取几种URL地址的方法小结
- JS获取几种URL地址的方法
- python获取本地的IP地址及mac地址
- JS获取html对象的几种方式介绍
- 本地获取图片的几种常用方式和网络获取图片
- 非常实用的本地天气获取控件
- js页面刷新跳转的几种方式及区别
- JS获取当前地区的天气信息和当前用户的IP地址
- android 本地存储的几种方式
- [总结]Android 获取本地视频文件路径并播放的几种方式
- MFC编程实现主机名及本地IP地址的获取
- JS获取MAC地址、IP地址及主机名的方法
- 每天一个linux命令(51):lsof命令
- X264参考手册
- JDk以及各个版本的区别
- Race Condition 引起的 HashMap CPU100%
- ssh-spring与struts整合
- js获取本地地址及天气的几种方式
- Android零基础入门第42节:自定义BaseAdapter
- 每天一个linux命令(52):ifconfig命令
- ListView的自定义适配器Adapter
- Cookbook for R-基础(翻译笔记)
- webstorm设置sass自动编译
- 点击一个按钮显示div,点击div之外的地方div隐藏,点击div之内的地方div不隐藏
- 关于使用MFC DLL时提示内存泄漏问题
- 51nod1298 圆与三角形(点到点,点到线段距离模板)