微信小程序 定位到当前城市实现实例代码
微信小程序定位到当前城市
首先需要申请百度地图GeocodingAPI
GeocodingAPI包括地址解析和逆地址解析功能:
1.地理编码:即地址解析,由详细到街道的结构化地址得到百度经纬度信息,例如:“北京市海淀区中关村南大街27号”地址解析的结果是“lng:116.31985,lat:39.959836”。同时,地理编码也支持名胜古迹、标志性建筑名称直接解析返回百度经纬度,例如:“百度大厦”地址解析的结果是“lng:116.30815,lat:40.056885”,通用的POI检索需求,建议使用PlaceAPI。
2.逆地理编码:即逆地址解析,由百度经纬度信息得到结构化地址信息,例如:“lat:31.325152,lng:120.558957”逆地址解析的结果是“江苏省苏州市虎丘区塔园路318号”。
代码:
Page({ data:{ city:'' }, onLoad:function(options){ this.loadInfo(); }, loadInfo:function(){ varpage=this wx.getLocation({ type:'wgs84',//默认为wgs84返回gps坐标,gcj02返回可用于wx.openLocation的坐标 success:function(res){ //success varlongitude=res.longitude varlatitude=res.latitude page.loadCity(longitude,latitude) }, fail:function(){ //fail }, complete:function(){ //complete } }) }, loadCity:function(longitude,latitude){ varpage=this wx.request({ url:'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location='+latitude+','+longitude+'&output=json', data:{}, header:{ 'Content-Type':'application/json' }, success:function(res){ //success console.log(res); varcity=res.data.result.addressComponent.city; page.setData({city:city}); }, fail:function(){ //fail }, complete:function(){ //complete } }) } })
index.wxml
<!--index.wxml--> <viewclass="container"> {{city}} </view>
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!