本文实例讲述了JS获取本地地址及天气的方法。分享给大家供大家参考,具体如下:
一、获取本地的地址
第一种方式:
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);
2、通过城市获取天气数据:
function getWeatherDatas(city) { var url='http://route.showapi.com/9-2""){ 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); } }); } }
更多关于JavaScript相关内容还可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript操作DOM技巧总结》及《JavaScript字符与字符串操作技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月15日
2024年11月15日
- 陈崎凡《CHEN》[320K/MP3][81.13MB]
- skt都在哪一年夺冠 英雄联盟skt夺冠赛季介绍
- 炉石传说抢先体验乱斗什么时候结束 深暗领域体验乱斗结束时间
- 炉石传说抢先乱斗卡组有什么 深暗领域抢先体验乱斗卡组推荐
- 荣耀手机腕上最佳搭档 荣耀手表5首销开启
- 雷克沙ARES 6000 C28战神之翼 AMD 9800X3D超强搭档
- 咪咕快游感恩同游,超值回馈尽在咪咕咪粉节!
- 陈崎凡《CHEN》[FLAC/分轨][326.32MB]
- 群星《我们的歌第六季 第2期》[320K/MP3][74.05MB]
- 群星《我们的歌第六季 第2期》[FLAC/分轨][385.16MB]
- 童丽《每一个晚上》[低速原抓WAV+CUE]
- 乌兰齐齐格《呼伦牧歌》[原抓WAV+CUE]
- 黄乙玲1988-无稳定的爱心肝乱糟糟[日本东芝1M版][WAV+CUE]
- 群星《我们的歌第六季 第3期》[320K/MP3][70.68MB]
- 群星《我们的歌第六季 第3期》[FLAC/分轨][369.48MB]