uniapp开发微信小程序通过高德Api获取城市信息和天气信息

通过uniapp提供的uni.getLocation,获取当前的地理位置、速度。在微信小程序中只能获取到当前的经纬度,无法获取到当前所在的城市信息。

uni.getLocation({
	type: 'wgs84',
	geocode:true,
	success: function (res) {
		console.log('当前位置的经度:' + res.longitude);
		console.log('当前位置的纬度:' + res.latitude);
	}
});

我们发现只能返回经纬度信息,并不会返回城市信息。

我们发现有只有app才支持geocode。

接下来我们通过使用高德地图提供的逆地理编码,通过经纬度拿到当前的城市信息。

首先,我们先在控制台申请一个key

 然后下载微信小程序插件

下载完成之后放入到项目中

这里需要把这个文件里面的最后的导出方式换成:

接下来我们就来实现通过经纬度获取当前的城市信息:

在页面中使用

uni.getLocation({
			type: 'gcj02',
			success: async (res) => {
                //先通过uniapp提供的api获取经纬度
				const { longitude, latitude } = res
				const result = await wxGetAddress(longitude, latitude)
                console.log("当前城市信息",result )
			},
			fail: (err) => {
				console.log("获取位置信息失败", err)
			}
		})

看一下我们拿到的信息

这样我们就通过逆地理编码拿到了我们的城市信息。

接下来我们通过拿到的城市信息去获取天气信息

我们可以看到,我们需要传递一个城市编码的参数,这个参数我们在上一步的获取城市信息的数据中就可以拿到:

然后在页面中使用:

const city = result[0].regeocodeData.addressComponent.adcode
const result1 = wxGetWeather(city)
console.log("天气",result1)

我们就可以获取当前的天气了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

safe030

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值