uniapp分别开发微信小程序和H5,通讯踩坑

前言

在混合开发场景中,我们使用uniapp同时开发了微信小程序和配套H5页面。但当H5需要与宿主小程序进行通讯交互时,却意外遭遇了长久的通讯协议地狱。本文将复盘我们尝试的4种方案及其背后的技术原理,最终成功实现动态通讯的方案。

一、为何需要跨端通讯?

业务中存在小程序无法显示物理公式、数学公式。那么在练习题结束之后,需要自动返回,这时候就需要.navigateBack();postMessage

二、四次方案迭代的血泪史

方案1:uni原生跳转(失败)

以为可以直接uni.navigateBack()就可以挑战到小程序的上一页。好的直接失败,并且刷新了H5界面

问题根源: 因为H5 也是uniapp开发的,所以直接调用的是当前项目(H5)。

方案2:引入uni-sdk、wx-sdk(失败)

xml 复制代码
<!-- 微信 JS-SDK  -->
<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script>
<!-- uni 的 SDK -->
<script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>

问题根源 : 我在index.html里面直接引入的window.wx.miniProgram直接undefind。现在回想不知道是不是因为我没有重启项目

方案3:静态引入微信JS-SDK(失败)

import webUni from './uni.webview.1.5.4.js'; import wx from './jweixin-1.3.2.js';

我在pages/course/index 界面中import使用后,调用webuni/wx还是失败。

方案4:动态注入SDK(成功✨)

ini 复制代码
	setwxSdk() {
		const script = document.createElement('script');
		// script.src = `/static/js/jweixin-1.6.0.js?v=${Date.now()}`; // 此方案无效
		script.src = 'https://res.wx.qq.com/open/js/jweixin-1.6.0.js'
		script.onload = () => {
			if (!window.wx.config) {
				console.error('微信 JS-SDK 未加载!');
				this.setwxSdk();
				return;
			}
			this.initWeixinSDK();

		};
		document.head.appendChild(script);
	}

三、通讯实现

javascript 复制代码
window.wx.ready(() => {
			window.wx.miniProgram.postMessage({
				data: {
					type: 'customEvent',
					content: 'Hello from UniApp H5!'
				}
			});
			window.wx.miniProgram.navigateBack();
		});

四、遗留问题

继续研究实时返回ing

相关推荐
ObjectX前端实验室43 分钟前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者1 小时前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱1 小时前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
路很长OoO1 小时前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos
开水好喝2 小时前
Code Coverage Part I
前端
DoraBigHead2 小时前
🧭 React 理念:让时间屈服于 UI —— 从同步到可中断的演化之路
前端·javascript·面试
敢敢J的憨憨L2 小时前
GPTL(General Purpose Timing Library)使用教程
java·服务器·前端·c++·轻量级计时工具库
喝拿铁写前端3 小时前
Vue 组件通信的两种世界观:`.sync` 与普通 `props` 到底有什么不同?
前端·vue.js·前端框架
美酒没故事°3 小时前
npm源管理器:nrm
前端·npm·npm源
用户22152044278003 小时前
vue3组件间的通讯方式
前端·vue.js