本篇文章主要讲解在微信小程序中,如何利用微信自带的api(wx.getLocation())结合百度地图的逆地址解析api来获取当前所在城市名。
实现起来也比较简单,步骤为:
1--利用微信小程序接口 wx.getLocation() 获取当前经纬度。使用简单,具体可以参照微信小程序api。
https://mp.weixin.qq.com/debug/wxadoc/dev/api/location.html#wxopenlocationobject
2--拿到经纬度之后,通过微信的wx.request()方法请求百度地图的解析接口,传入我们获取到的经纬度,拿到当前定位的城市。
接口为:
url: 'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location=' + lat + ',' + log + '&output=json'
注意ak后面不要加空格
ak需要在百度地图api官网去注册,然后创建一个应用,如此便可拿到您的ak。
index.js代码如下:
// pages/mine/set/set.js
Page({
data: {
format_address: ''
},
getlocation () {
var self = this
wx.getLocation({
type: 'wgs84',
altitude: true,
success: function (res) {
var log = res.longitude
var lat = res.latitude
self.loadCity(log, lat)
},
fail: function (res) { },
complete: function (res) { },
})
},
loadCity:function(log, lat) {
var self = this
wx.request({
url: 'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location=' + lat + ',' + log + '&output=json',
data: {},
header: {
'Content-Type': 'application/json'
},
success: function (res) {
var city = res.data.result.formatted_address;
self.setData({ format_address: city });
},
fail: function () {},
complete: function () {}
})
}
})
loadCity()方法中,获取到信息之后打印出来,拿到的信息是非常详细的,如下图:
效果如下
申请百度地图ak方式
下面根据需求来填