微信小程序获取当前所在城市

Myth丶恋晨 2022-05-31 06:47 952阅读 0赞

本篇文章主要讲解在微信小程序中,如何利用微信自带的api(wx.getLocation())结合百度地图的逆地址解析api来获取当前所在城市名。

实现起来也比较简单,步骤为:

1—利用微信小程序接口 wx.getLocation() 获取当前经纬度。使用简单,具体可以参照微信小程序api。

https://mp.weixin.qq.com/debug/wxadoc/dev/api/location.html\#wxopenlocationobject

2—拿到经纬度之后,通过微信的wx.request()方法请求百度地图的解析接口,传入我们获取到的经纬度,拿到当前定位的城市。

接口为:

  1. url: 'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location=' + lat + ',' + log + '&output=json'

注意ak后面不要加空格

ak需要在百度地图api官网去注册,然后创建一个应用,如此便可拿到您的ak。

index.js代码如下:

  1. // pages/mine/set/set.js
  2. Page({
  3. data: {
  4. format_address: ''
  5. },
  6. getlocation () {
  7. var self = this
  8. wx.getLocation({
  9. type: 'wgs84',
  10. altitude: true,
  11. success: function (res) {
  12. var log = res.longitude
  13. var lat = res.latitude
  14. self.loadCity(log, lat)
  15. },
  16. fail: function (res) { },
  17. complete: function (res) { },
  18. })
  19. },
  20. loadCity:function(log, lat) {
  21. var self = this
  22. wx.request({
  23. url: 'https://api.map.baidu.com/geocoder/v2/?ak=您的ak&location=' + lat + ',' + log + '&output=json',
  24. data: {},
  25. header: {
  26. 'Content-Type': 'application/json'
  27. },
  28. success: function (res) {
  29. var city = res.data.result.formatted_address;
  30. self.setData({ format_address: city });
  31. },
  32. fail: function () {},
  33. complete: function () {}
  34. })
  35. }
  36. })

loadCity()方法中,获取到信息之后打印出来,拿到的信息是非常详细的,如下图:

70

效果如下

70 1

申请百度地图ak方式

70 2

下面根据需求来填

70 3

发表评论

表情:
评论列表 (有 0 条评论,952人围观)

还没有评论,来说两句吧...

相关阅读