微信小程序獲取當前所在城市


本篇文章主要講解在微信小程序中,如何利用微信自帶的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=' + latitude + ',' + longitude + '&output=json'
ak需要在百度地圖api官網去注冊,然后創建一個應用,如此便可拿到您的ak。


index.js代碼如下:

Page({
data: {
currentCity: ''
},
onLoad: function (options) {
this.getLocation();
},
getLocation: 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)
}
})
},
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代碼如下:
<!--index.wxml-->
<view class="container">
當前城市為:{{currentCity}}
</view>

效果如下:

 

 

 

 


文章參考來自:http://blog.csdn.net/tammy1151/article/details/56494776


---------------------
作者:Tiramisu_C
來源:CSDN
原文:https://blog.csdn.net/nongweiyilady/article/details/74314747
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM