本篇文章主要講解在微信小程序中,如何利用微信自帶的api(wx.getLocation())結合百度地圖的逆地址解析api來獲取當前所在城市名。
實現起來也比較簡單,步驟為:
1--利用微信小程序接口 wx.getLocation() 獲取當前經緯度。使用簡單,具體可以參照微信小程序api。
https://mp.weixin.qq.com/debug/wxadoc/dev/api/location.html#wxopenlocationobject
2--拿到經緯度之后,通過微信的wx.request()方法請求百度地圖的解析接口,傳入我們獲取到的經緯度,拿到當前定位的城市。
接口為:
[javascript] view plain copy
print?
-
url: 'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location=' + latitude + ',' + longitude + '&output=json'
ak需要在百度地圖api官網去注冊,然后創建一個應用,如此便可拿到您的ak。
index.js代碼如下:
[javascript] view plain copy
print?
-
Page({
-
data: {
-
currentCity: ''
-
},
-
onLoad: function (options) {
-
this.getLocation();
-
},
-
getLocation: function () {
-
var page = this
-
wx.getLocation({
-
type: 'wgs84', //<span class="comment" style="margin: 0px; padding: 0px; border: none;">默認為 wgs84 返回 gps 坐標,gcj02 返回可用于 wx.openLocation 的坐標</span><span style="margin: 0px; padding: 0px; border: none;"> </span>
-
success: function (res) {
-
// success
-
var longitude = res.longitude
-
var latitude = res.latitude
-
page.loadCity(longitude, latitude)
-
}
-
})
-
},
-
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({ currentCity: city });
-
},
-
fail: function () {
-
page.setData({ currentCity: "獲取定位失敗" });
-
},
-
-
})
-
}
-
})
loadCity()方法中,獲取到信息之后打印出來,拿到的信息是非常詳細的,如下圖:

我們這里需要的是當前的city,即:res.data.result.addressComponent.city。如果項目中有需要更加豐富的信息,也可使用此方法,比較簡便。
index.wxml代碼如下:
[html] view plain copy
print?
-
<!--index.wxml-->
-
<view class="container">
-
當前城市為:{{currentCity}}
-
</view>
|