【uniapp*vue3】app/h5 webview通讯方案

本文旨在解决vue3版本下uniapp h5项目向app项目中webview通讯问题

问题产生于uniapp不支持vue3使用template.h5.html 自定义打包模板

h5向app发送信息

有很多文章指出h5项目使用uni.postmessage 这个api需要在template.h5.html引入一个js文件 然后改下webuni变量再从manifest.json配置下改文件 就可以全文使用了

vue2环境是可以参考的

文章指向通信跳转文章

但这方案在vue3环境下是无法使用的

vue3的解决方案是直接在需要使用的页面import引入该文件

直接调用webUni.postMessage即可

javascript 复制代码
<script lang="ts" setup>
	import { MessageUtil } from "@/utils/MessageUtil";
	import webUni from '@/static/js/uni.webview.js'
	
	const saveImage = ()=>{
		webUni.postMessage({ data: { action: 'download', data: 'http://mj-1302596703.cos.ap-guangzhou.myqcloud.com/file/ttc7sKc4g0mcSL2KbtJg.png' } });
	}
</script>

接下来的问题就细化成将js文件改造成可支持model暴露了

javascript 复制代码
const webUni = (function() {
    "use strict";
    try {
        var e = {};
        Object.defineProperty(e, "passive", {
            get: function() {
                return true;
            }
        }), window.addEventListener("test-passive", null, e)
    } catch (e) {}

    var n = Object.prototype.hasOwnProperty;

    function t(e, t) {
        return n.call(e, t);
    }

    var i = [],
        a = function(e, n) {
            var t = {
                options: {
                    timestamp: +new Date
                },
                name: e,
                arg: n
            };
            if (window.__dcloud_weex_postMessage || window.__dcloud_weex_) {
                if ("postMessage" === e) {
                    var a = {
                        data: [n]
                    };
                    return window.__dcloud_weex_postMessage ? window.__dcloud_weex_postMessage(a) : window.__dcloud_weex_.postMessage(JSON.stringify(a));
                }
                var o = {
                    type: "WEB_INVOKE_APPSERVICE",
                    args: {
                        data: t,
                        webviewIds: i
                    }
                };
                window.__dcloud_weex_postMessage ? window.__dcloud_weex_postMessageToService(o) : window.__dcloud_weex_.postMessageToService(JSON.stringify(o));
            }
            if (!window.plus) return window.parent.postMessage({
                type: "WEB_INVOKE_APPSERVICE",
                data: t,
                pageId: ""
            }, "*");
            if (0 === i.length) {
                var r = plus.webview.currentWebview();
                if (!r) throw new Error("plus.webview.currentWebview() is undefined");
                var d = r.parent(),
                    s = "";
                s = d ? d.id : r.id, i.push(s);
            }
            if (plus.webview.getWebviewById("__uniapp__service")) plus.webview.postMessageToUniNView({
                type: "WEB_INVOKE_APPSERVICE",
                args: {
                    data: t,
                    webviewIds: i
                }
            }, "__uniapp__service");
            else {
                var w = JSON.stringify(t);
                plus.webview.getLaunchWebview().evalJS('UniPlusBridge.subscribeHandler("'.concat("WEB_INVOKE_APPSERVICE", '",').concat(w, ",").concat(JSON.stringify(i), ");"));
            }
        },
        o = {
            navigateTo: function(e) {
                var n = e.url;
                a("navigateTo", {
                    url: encodeURI(n)
                });
            },
            navigateBack: function(e) {
                var n = e.delta;
                a("navigateBack", {
                    delta: parseInt(n) || 1
                });
            },
            switchTab: function(e) {
                var n = e.url;
                a("switchTab", {
                    url: encodeURI(n)
                });
            },
            reLaunch: function(e) {
                var n = e.url;
                a("reLaunch", {
                    url: encodeURI(n)
                });
            },
            redirectTo: function(e) {
                var n = e.url;
                a("redirectTo", {
                    url: encodeURI(n)
                });
            },
            getEnv: function(callback) {
                window.plus ? callback({
                    plus: true
                }) : callback({
                    h5: true
                });
            },
            postMessage: function(e) {
                a("postMessage", e.data || {});
            }
        };

    return o;
})();

export default webUni;

直接将其替换官方提供的文件代码就能使用了

app接收

javascript 复制代码
<web-view :webview-styles="webviewStyles" :src="url" @message="handlePostMessage"></web-view>


handlePostMessage(evt) {
			let data = evt.detail.data[0];
			const action = data?.action;
			switch (action) {
				case 'download': {
					saveFileToPhotosAlbum(data.data)
					break;
				}
			}
		},
相关推荐
用户69903048487515 小时前
try catch使用场景 处理同步代码错误兼容用的
javascript·uni-app
ITKEY_16 小时前
uniapp微信开发者工具 更改AppID失败 touristappid
uni-app
Geek_Vison1 天前
APP瘦身实战:从80MB+砍到15MB——基于小程序容器技术剥离APP非核心业务的实践分享
小程序·uni-app·mpaas
CHB2 天前
HDC2026 演讲实录|AI 驱动的跨端进化:利用 uni-agent 快速构建高性能鸿蒙应用
uni-app·harmonyos
2501_915918412 天前
iOS App性能测试工具的实现方法与优化循环指南
android·ios·小程序·https·uni-app·iphone·webview
斯内普吖2 天前
(开源)高校素拓分管理系统小程序实战指南 基于 Java + SpringBoot + uni-app + Vue + MySQL
java·spring boot·mysql·小程序·uni-app·开源
海阔天空66882 天前
uniapp开启调试模式
uni-app·uniapp开启调试模式
anyup3 天前
分享 5 套 uni-app 实用主题,一键适配暗黑模式
前端·uni-app·视觉设计
gg159357284603 天前
Uni-app跨平台开发全解课程:从零基础到企业级多端落地实战
vue.js·uni-app
xshirleyl4 天前
uniapp小兔鲜儿day3
uni-app