uniapp如何使用 web-view 与网页互相通信
更新时间:2024年07月17日 10:51:10 作者:以对_
这篇文章主要介绍了uniapp如何使用 web-view 与网页互相通信,在APP中使用 this.$scope.$getAppWebview() 获取webview对象实例,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
在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>
到此这篇关于uniapp使用 web-view 与网页互相通信的文章就介绍到这了,更多相关uniapp网页互相通信内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
兼容Firefox的Javascript XSLT 处理XML文件
这篇文章主要介绍了兼容Firefox的Javascript XSLT 处理XML文件,需要的朋友可以参考下2014-12-12javascript实现简约的页面右下角点击弹出窗口示例【测试可用】
这篇文章主要介绍了javascript实现的页面右下角点击弹出窗口功能,结合实例形式详细分析了javascript页面右下角点击弹出窗口功能的相关步骤、原理与注意事项,需要的朋友可以参考下2023-07-07
最新评论