JS获取本地地址及天气的方法实例小结
本文实例讲述了JS获取本地地址及天气的方法。分享给大家供大家参考,具体如下:
一、获取本地的地址
第一种方式:
1、利用浏览器获取当前位置的经纬度
window.onload=getCurrentPosition; //浏览器获取当前位置 functiongetCurrentPosition(){ if(window.navigator.geolocation){ varoptions={ enableHighAccuracy:true, }; window.navigator.geolocation.getCurrentPosition(handleSuccess,handleError,options); }else{ alert("浏览器不支持html5来获取地理位置信息"); } }
2、浏览器获取到的是GPS坐标,需要转换成城市名称再通过城市获取天气:
//成功获取时调用的函数 functionhandleSuccess(position){ //获取到当前位置经纬度本例中获取到的是gps坐标系 //经度 varlng=position.coords.longitude; //纬度 varlat=position.coords.latitude; //转换成百度坐标系 //将请求发送给‘ varggPoint=newBMap.Point(lng,lat); //地图初始化 varbm=newBMap.Map(); //坐标转换完之后的回调函数 translateCallback=function(data){ if(data.status===0){//回调成功 varmarker=newBMap.Marker(data.points[0]); varmyGeo=newBMap.Geocoder(); varbaiduPoint=newBMap.Point(data.points[0].lng,data.points[0].lat); //将经纬度转换成城市 myGeo.getLocation(baiduPoint,getCityByCoordinate); } } setTimeout(function(){ varconvertor=newBMap.Convertor(); varpointArr=[]; pointArr.push(ggPoint); convertor.translate(pointArr,3,5,translateCallback) },2000); } functiongetCityByCoordinate(result){ vargpsAadress=result.addressComponents; varcity=gpsAadress.city; //将转换之后的城市传入获取天气的函数做参数 getWeatherDatas(city); returncity; } functionhandleError(){ log('地点定位出错'); }
第二种方式:
1、利用百度API通过IP地址获取本地地址
//通过百度的IP地址获取本地地址 window.onload=getCurrentPosit; functiongetCurrentPosit(){ varmap=newBMap.Map('getCity'); functionmyFun(result){ varcityName=result.name; getWeatherDatasFun(cityName); map.setCenter(cityName); alert("当前定位城市:"+cityName); } varmyCity=newBMap.LocalCity(); myCity.get(myFun);
2、通过城市获取天气数据:
functiongetWeatherDatas(city){ varurl='http://route.showapi.com/9-2?'; if(city===undefined||city===""){ log('您还未输入') }else{ $.ajax({ type:'post', url:url, dataType:'jsonp', data:{ "showapi_timestamp":newDate().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('TheWeatherdatas:',result); } }); } }
更多关于JavaScript相关内容还可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript事件相关操作与技巧大全》、《JavaScript操作DOM技巧总结》及《JavaScript字符与字符串操作技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。