uniapp实现小程序地图导航

效果图:

js 复制代码
	const target = computed(() => ({
		lat: data.value?.latitude || 22.525294,
		lng: data.value?.longitude || 113.94319,
		destination: data.value.address || ''
	}));
	// 点击按钮触发:先授权定位,再唤起地图
	const handleOpenLocation = () => {
		wx.getSetting({
			success(res) {
				const locationAuth = res.authSetting['scope.userLocation']
				if (locationAuth === undefined) {
					wx.authorize({
						scope: 'scope.userLocation',
						success() {
							openLocationFn();
						},
						fail() {
							console.log('授权失败:', err);
							wx.showToast({
								title: '拒绝授权后无法使用导航',
								icon: 'none'
							});
						}
					});
				} else if (locationAuth === false) {
					wx.showModal({
						title: '需要位置权限',
						content: '你已拒绝位置授权,请手动开启:点击右上角「···」→「设置」→「位置信息」→「允许」',
						confirmText: '知道了'
					});
				} else {
					openLocationFn();
				}
			},
			fail() {
				wx.showToast({
					title: '获取权限设置失败',
					icon: 'none'
				});
			}
		});
	};

	// 封装:调用wx.openLocation
	const openLocationFn = () => {
		wx.openLocation({
			latitude: parseFloat(target.value.lat),
			longitude: parseFloat(target.value.lng),
			name: target.value.destination,
			scale: 18,
			success() {
				console.log('唤起微信地图成功,用户可选择Apple/腾讯/高德导航');
			},
			fail(err) {
				wx.showToast({
					title: `唤起失败:${err.errMsg}`,
					icon: 'none'
				});
			}
		});
	};
相关推荐
超绝大帅哥13 小时前
React的Fiber是什么? Vue为什么不需要Fiber ?
前端
yingyima13 小时前
正则表达式分组与捕获:凌晨3点服务器报警的解决方案
前端
swipe14 小时前
从 0 到 1 理解 React 虚拟列表:定高、不定高与 Canvas 版本完整拆解
前端·javascript·面试
铁皮饭盒14 小时前
Bun执行python代码
前端·javascript·后端
hunterandroid15 小时前
Service 与前台服务:让任务在后台持续运行
前端
米饭同学i15 小时前
深扒 LobsterAI 官网前端动效实现方案:从交互细节到代码实践
前端
前端啊15 小时前
告别 el-table 打印难题,vue3-print-el-table 来了!
前端·vue.js
JarvanMo15 小时前
AI时代跨平台还有必要吗?
前端
Patrick_Wilson15 小时前
幂等到底是什么?从前端视角讲透 SQL、HTTP 与 POST 接口的幂等设计
前端·后端·架构
凌览15 小时前
一人公司别再上 Jenkins,真不值
前端·后端