uniapp webview实现双向通信

需求:uniapp webview嵌套一个h5 实现双向通信

  • uniapp 代码
<template>
	<view>
		<web-view src="http://192.168.3.150:9003/" @message="onMessage"></web-view>
	</view>
</template>

<script>
	export default {
		data(){
			return{
				currentWebview:null
			}
		},
		mounted() {
			const self = this;
			self.currentWebview = self.$scope.$getAppWebview().children()[0]
			let info = {name:'hello'}
			self.currentWebview.evalJS(`uniEvent(${JSON.stringify(info)})`);
			setInterval(() => {
					self.currentWebview.evalJS(`uniEvent(${JSON.stringify(info)})`);
			},1000)
		},

		methods: {
			onMessage(e) {
				console.log('来自页面的消息', e.detail.data);
				uni.showToast({
					title: e.detail.data, 
					icon: 'none'
				});
			}
		}
	}
</script>
  • h5 页面代码
<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="content-type" content="text/html; charset=utf-8" />
    <title>测试</title>
    <script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>
</head>
<body onload="addUniEvenPassthrough()">
    <div class="margin-top:200px;"></div>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <button onclick="sendMessage()">Send message to uniapp</button>
    <script>
    function sendMessage() {
        uni.postMessage({
            data: 'Hello from web page!'
        });
    }
    function addUniEvenPassthrough() {
        window.uniEvent = function(info) {
            console.log('webview通信', JSON.stringify(info));
        }
    }
    </script>
</body>
</html>
  • 效果
    在这里插入图片描述
    在这里插入图片描述

ps: 如果你webview嵌套的h5 是uniapp打包出来的 那么uni.postMessage 方法调用不成功的话,成得改成 uni.webView.postMessage

在这里插入图片描述

  • 这样就成功了
    在这里插入图片描述
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值