微信小程序 定位到当前城市
首先需要申请百度地图geocoding api
geocoding api包括地址解析和逆地址解析功能:
1.地理编码:即地址解析,由详细到街道的结构化地址得到百度经纬度信息,例如:“北京市海淀区中关村南大街27号”地址解析的结果是“lng:116.31985,lat:39.959836”。同时,地理编码也支持名胜古迹、标志性建筑名称直接解析返回百度经纬度,例如:“百度大厦”地址解析的结果是“lng:116.30815,lat:40.056885” ,通用的poi检索需求,建议使用place api。
2.逆地理编码:即逆地址解析,由百度经纬度信息得到结构化地址信息,例如:“lat:31.325152,lng:120.558957”逆地址解析的结果是“江苏省苏州市虎丘区塔园路318号”。
代码:
page({
data:{
city:''
},
onload:function(options){
this.loadinfo();
},
loadinfo:function(){
var page=this
wx.getlocation({
type: 'wgs84', // 默认为 wgs84 返回 gps 坐标,gcj02 返回可用于 wx.openlocation 的坐标
success: function(res){
// success
var longitude=res.longitude
var latitude=res.latitude
page.loadcity(longitude,latitude)
},
fail: function() {
// fail
},
complete: function() {
// complete
}
})
},
loadcity:function(longitude,latitude){
var page =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);
var city=res.data.result.addresscomponent.city;
page.setdata({city:city});
},
fail: function() {
// fail
},
complete: function() {
// complete
}
})
}
})
index.wxml
<!--index.wxml-->
<view class="container">
pw_city
</view>
以上就是微信小程序开发之定位到当前城市方法讲解的详细内容。