uniapp webview嵌入外部h5网页后的消息通知

最近开发了个oa系统,pc端的表单使用form-create开发,form-create 是一个可以通过 JSON 生成具有动态渲染、数据收集、验证和提交功能的表单生成组件。移动端使用uniapp开发,但是因为form-create移动端只支持vant,不支持uniapp。官方的说法是移动端用vant开发后通过webview的方式嵌入到uniapp。

uniapp嵌入开发好的h5页面没有问题,但是h5页面需要保存表单数据和发起工作流,做完这个操作后需要告知uniapp关闭webview页面,并跳转uniapp相应页面。

(1)uniapp 的webview.vue页面:

TypeScript 复制代码
<template>
	<view>
		<web-view :src="fileUrl" @message="handlerMessage"></web-view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				fileUrl: "",
			}
		},
		onLoad(options) {
			this.fileUrl = decodeURIComponent(options.fileUrl)
		},
		methods: {
			handlerMessage(event) {
				console.log('Received message:', event.detail.data);
			}
		}
	}
</script>

<style>

</style>

webview页面使用message方法监听h5发送给uniapp应用的消息。

(2)h5推送消息至uniapp

我的h5页面基于vue3+vant4+vite开发。

1.首先在public目录下新建static目录,接着创建js目录。下载jweixin-1.4.0.jsuni.webview.1.5.6.js文件到本地,引入到js目录下。

2.在项目index.html中写入如下内容:

javascript 复制代码
<!DOCTYPE html>
<html lang="">
<head>
    <meta charset="UTF-8">
    <link rel="icon" href="/favicon.ico">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>流程表单</title>
</head>
<body>
<div id="app"></div>
<script type="module" src="/src/main.ts"></script>
<script type="text/javascript" src="/static/js/jweixin-1.4.0.js"></script>
<script type="text/javascript" src="/static/js/uni.webview.1.5.6.js"></script>
<script>
    document.addEventListener('UniAppJSBridgeReady', function () {
        uni.getEnv(function (res) {
            if (res.plus) {
                console.log('当前环境为【5+App】');
            } else if (res.miniprogram) {
                console.log('当前环境为【微信小程序】');
            } else if (res.h5) {
                console.log('当前环境为h5');
            }
        });
    });
</script>
</body>
</html>

3.在h5页面,保存按钮点击时调用下面的方法。

javascript 复制代码
//提交
async function onSubmit(formData) {
  let params = {
    procdefKey: processDefKey,
    formData: JSON.stringify(formData)
  };
  try {
    loading.value = true
    await apiSaveFormStartProcess(params);
    
    uni.postMessage({
      data: {
        action: 'startProcessCompleted'
      }
    });
    
    showSuccessToast('流程发起成功');
    uni.navigateBack({
      delta: 1
    });
  } finally {
    loading.value = false
  }
}

uni.postMessage推送消息到uniapp应用。由于message在后退、组件销毁、分享才会接受到消息。所以在提交完后,调用 uni.navigateBack触发后退。此时webview的message方法就能接受到消息了。

(3)效果

相关推荐
阿斌_bingyu7092 分钟前
uniapp实现android/IOS消息推送
android·ios·uni-app
说私域4 小时前
定制开发AI智能名片S2B2C预约服务小程序的定制开发与优势分析
大数据·人工智能·小程序
茶憶4 小时前
UniApp RenderJS中集成 Leaflet地图,突破APP跨端开发限制
javascript·vue.js·uni-app
云起SAAS12 小时前
名字姓名起名打分评分抖音快手微信小程序看广告流量主开源
微信小程序·小程序·ai编程·看广告变现轻·名字姓名起名打分评分
说私域13 小时前
从裂变能力竞争到技术水平竞争:开源AI智能名片链动2+1模式S2B2C商城小程序对微商企业竞争格局的重塑
人工智能·小程序·开源
开发加微信:hedian11616 小时前
短剧小程序开发全攻略:技术选型与实现思路
微信·小程序·架构·aigc·交互
2501_9159184116 小时前
移动端 HTTPS 抓包实战,多工具组合分析与高效排查指南
数据库·网络协议·ios·小程序·https·uni-app·iphone
雪芽蓝域zzs20 小时前
uni-app 将 base64 图片编码转为 Blob 本地文件路径
网络协议·udp·uni-app
星光一影1 天前
陪诊陪检系统源码,陪诊小程序,陪诊APP,陪诊服务,家政上门系统,居家护理陪护源码
mysql·小程序·uni-app·php
Qlittleboy1 天前
uniapp里 rich-text 里的img图片如何控制最大宽度
uni-app