uniapp使用 web-view 与网页互相通信

在APP中使用 this.$scope.$getAppWebview() 获取webview对象实例
通过evalJS可以为这个webview注入一段js,从而去调用网页中的对象

<template>  
    <view>  
      <web-view ref="webview" src="http://192.168.1.79:6446/demo.html" @message="handleMessage"></web-view> 
    </view>  
</template>  

<script>  
	var wv;
	export default {  
		onLoad() { 
			var currentWebview = this.$scope.$getAppWebview(); //获取当前页面的webview对象    
			setTimeout(function() {  
				wv = currentWebview.children()[0];  
			}, 300); //如果是页面初始化调用时,需要延时一下 
		},
		methods: {  
      // 接收网页中发送来的消息
			handleMessage(evt) { 
				console.log('接收到的消息:' + JSON.stringify(evt));  
				this.evalJS()
			},
			evalJS() {
				wv.evalJS(`
					num+=1; // 网页中的变量
					alertaa() // 网页中的事件
				`)
			}
		}  
	}  
</script>

网页中调用uniapp的方法需要引入uni 的 SDK

<!-- 微信 JS-SDK 如果不需要兼容小程序,则无需引用此 JS 文件。 -->  
<script type="text/javascript" src="//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.1.js"></script>  
<script>

在网页中调用uniapp中的postMessage方法,在 的 message 事件回调 event.detail.data 中接收消息。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <button id="test">onPostMessage</button>
  <p id="num"></p>

  <!-- 微信 JS-SDK 如果不需要兼容小程序,则无需引用此 JS 文件。 -->  
  <script type="text/javascript" src="//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.1.js"></script>  
  <script>
    var num = 1;

    document.getElementById("num").innerText = num;

    document.getElementById("test").onclick=()=>{
      console.log('clickHandle :>> ', );
      uni.getEnv(function(res) { // 使用getEnv可以判断当前环境
        console.log("当前环境:" + JSON.stringify(res));
      });
      uni.postMessage({  // 调用uniapp中的postMessage方法
        data: {  
            action: 'onPostMessage'  
        }  
      });  
    }

    function alertaa() {
      alert("evalJS"+num);
    }
  </script>
</body>
</html>

相关推荐

  1. uniapp使用 web-view 网页互相通信

    2024-07-17 13:54:04       21 阅读
  2. uniappweb-view嵌套网页地址并传参

    2024-07-17 13:54:04       48 阅读
  3. uniappweb-view 嵌套uniapp

    2024-07-17 13:54:04       31 阅读
  4. uniapp得cover-view标签使用

    2024-07-17 13:54:04       52 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-17 13:54:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-17 13:54:04       71 阅读
  3. 在Django里面运行非项目文件

    2024-07-17 13:54:04       58 阅读
  4. Python语言-面向对象

    2024-07-17 13:54:04       69 阅读

热门阅读

  1. Arrays的用法(附10道练习题)

    2024-07-17 13:54:04       24 阅读
  2. Hadoop之/etc目录下各配置文件的作用详解

    2024-07-17 13:54:04       18 阅读
  3. 前端学习常用技术栈

    2024-07-17 13:54:04       23 阅读
  4. Perl语言入门学习

    2024-07-17 13:54:04       20 阅读
  5. 【闲聊】-Perl的基础语法

    2024-07-17 13:54:04       24 阅读
  6. LVS的NAT方式

    2024-07-17 13:54:04       18 阅读
  7. SAP中MIR4使用的BAPI是什么,如何使用?

    2024-07-17 13:54:04       21 阅读
  8. cuda--docker

    2024-07-17 13:54:04       25 阅读
  9. WHAT - 介绍一个不太一样的 UI 组件库 shadcn/ui

    2024-07-17 13:54:04       19 阅读