php手机获取当前城市地图,微信小程序获取当前所在城市 百度地图和腾讯地图...

本篇文章主要讲解在微信小程序中,如何利用微信自带的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。url: 'https://apis.map.qq.com/ws/geocoder/v1/?location=' + latitude + ',' + longitude + '&key=你的key'

'

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代码如下:

当前城市为:{{currentCity}}

效果如下:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值