Page({
data: {
latitude: 0,
longitude: 0,
},
onLoad: function () {
// 初始化获取一次地理位置
this.getLocation();
// 定时器每隔一定时间获取一次地理位置
setInterval(() => {
this.getLocation();
}, 5000); // 间隔时间为5秒,可以根据实际需求调整
},
getLocation: function () {
wx.getLocation({
type: 'gcj02', // 返回的坐标系类型,可以选择 'wgs84'、'gcj02'、'bd09'
success: (res) => {
const latitude = res.latitude;
const longitude = res.longitude;
console.log('当前位置:', latitude, longitude);
// 更新页面数据
this.setData({
latitude: latitude,
longitude: longitude,
});
},
fail: (error) => {
console.error('获取位置失败', error);
},
});
},
});
在这个示例中,通过在 onLoad 生命周期中初始化获取一次地理位置,并使用定时器每隔一定时间获取一次地理位置,实现了实时地理位置的更新。你可以根据实际需求选择合适的定时器间隔。
请注意,获取地理位置需要用户授权,因此在使用这个功能时,确保已经向用户请求了相应的权限。
另外,需要注意的是,实时地理位置监听可能会对用户设备的电池寿命产生一定的影响,因此在使用时请考虑用户体验和电量消耗。
转载请注明出处:http://www.pingtaimeng.com/article/detail/927/微信小程序