小程序webview我爱死你了 小程序webview和H5通讯

webview 我 *

众所周知,将已上线的H5页面转换为小程序,最快的方法是通过WebView进行套壳。然而,在这个过程中,我们需要将H5页面的登录和支付功能迁移到小程序版本。这意味着H5页面需通过特定的方式与小程序进行通信,以实现如支付等关键功能。

因此需要了解H5与WebView之间的通讯方式,以确保数据的顺利传递和功能的无缝对接。

找了很久发现H5与WebView的通讯方式主要有两种

  1. 小程序通过改变H5地址栏携带参数
  2. WebSocket实时通讯

而webview自带的bindmessage、bindload、binderror,触发条件只有小程序后退、组件销毁、分享、复制链接,给我卡的死死的,只好选择了第一种方式,WebSocket虽然可以实现实时通讯,但会增加额外的开销,不符合我的需求。

这里的URL域名必须添加到 小程序后台中-管理-业务域名内,否则会报无法打开 xxx 页面,个人小程序是没有这个选项的,需要申请成企业小程序

小程序向H5通讯

小程序端

js 复制代码
<view class="content">
		<web-view :src="url"></web-view>
	</view>

H5端

js 复制代码
// 判断当前页面的 URL 是否包含 'userInfo',用于识别是否来自小程序端
if (window.location.href.includes('userInfo')) {  
    // 匹配 URL 中的 userInfo 参数
    const userInfoRegex = /userInfo=([^]*)/; 

    // 解码
    const decodedUrl = decodeURIComponent(window.location.href); 

    // 使用正则表达式从解码后的 URL 中提取参数值
    const userInfoMatch = decodedUrl.match(userInfoRegex);
    let auth_token =  userInfoMatch[1];
    localStorage.setItem('loc_token', auth_token);
}
H5向小程序通讯

小程序端

js 复制代码
onMounted(() => {
	const paymentData = getCurrentPages().pop().options.paymentData // 获取当前页面参数
	submitInfo(paymentData);
	});

H5端

js 复制代码
 wx.miniProgram.navigateTo({
          url: `/pagesMember/pay/pay?paymentData=${payInfo.value}`,
        })

通讯限制也就算了,导航栏不能自定义,还不让去掉,这让自带导航栏显得极其突兀!我 * !!!

navigationStyle: custom对 web-view 组件无效 一句话干碎我的摸鱼梦,领导要把那块做成透明的,没办法只好把常用页面重构, but小程序不支持elementPlus啊,太爽了家人们。

相关推荐
yqcoder2 分钟前
CSS 外边距重叠(Margin Collapsing):现象、原理与完美解决方案
前端·css
山楂树の1 小时前
图像标注大坑:img图片 + Canvas 叠加标注,同步放大后标注位置偏移、对不齐?详解修复方案及亚像素处理原理
前端·css·学习·canva可画
本山德彪1 小时前
我做了一个拼豆图纸生成器,把照片秒变图纸
前端
DTrader1 小时前
用TS无法实盘量化? - 实盘均线策略
前端·api
进击的夸父1 小时前
vfojs:Vue 超集架构,外壳React灵魂Vue
前端
编程老船长1 小时前
解决不同项目需要不同 Node.js 版本的问题
前端·vue.js
Wect1 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·算法·typescript
漫游的渔夫1 小时前
前端开发者做 Agent:别写成一次请求,用 5 步受控循环防止 AI 乱跑
前端·人工智能·typescript
kyriewen3 小时前
Webpack vs Vite:一个是“老黄牛”,一个是“猎豹”,你选谁?
前端·webpack·vite
打小就很皮...3 小时前
html2canvas + jsPDF 生成 PDF 的踩坑与解决方案总结
前端·pdf