uniapp如何使用 web-view 與網(wǎng)頁(yè)互相通信
在APP中使用 this.$scope.$getAppWebview()
獲取webview對(duì)象實(shí)例
通過(guò)evalJS可以為這個(gè)webview注入一段js,從而去調(diào)用網(wǎng)頁(yè)中的對(duì)象
<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(); //獲取當(dāng)前頁(yè)面的webview對(duì)象 setTimeout(function() { wv = currentWebview.children()[0]; }, 300); //如果是頁(yè)面初始化調(diào)用時(shí),需要延時(shí)一下 }, methods: { // 接收網(wǎng)頁(yè)中發(fā)送來(lái)的消息 handleMessage(evt) { console.log('接收到的消息:' + JSON.stringify(evt)); this.evalJS() }, evalJS() { wv.evalJS(` num+=1; // 網(wǎng)頁(yè)中的變量 alertaa() // 網(wǎng)頁(yè)中的事件 `) } } } </script>
網(wǎng)頁(yè)中調(diào)用uniapp的方法需要引入uni 的 SDK
<!-- 微信 JS-SDK 如果不需要兼容小程序,則無(wú)需引用此 JS 文件。 --> <script type="text/javascript" src="http://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>
在網(wǎng)頁(yè)中調(diào)用uniapp中的postMessage方法,在 的 message 事件回調(diào) 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 如果不需要兼容小程序,則無(wú)需引用此 JS 文件。 --> <script type="text/javascript" src="http://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可以判斷當(dāng)前環(huán)境 console.log("當(dāng)前環(huán)境:" + JSON.stringify(res)); }); uni.postMessage({ // 調(diào)用uniapp中的postMessage方法 data: { action: 'onPostMessage' } }); } function alertaa() { alert("evalJS"+num); } </script> </body> </html>
到此這篇關(guān)于uniapp使用 web-view 與網(wǎng)頁(yè)互相通信的文章就介紹到這了,更多相關(guān)uniapp網(wǎng)頁(yè)互相通信內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
bootstrap datepicker限定可選時(shí)間范圍實(shí)現(xiàn)方法
這篇文章主要介紹了bootstrap datepicker限定可選時(shí)間范圍的實(shí)現(xiàn)方法,本文涉及到相關(guān)知識(shí)點(diǎn),通過(guò)實(shí)例給大家介紹的非常詳細(xì),需要的朋友可以參考下2016-09-09表單元素值獲取方式j(luò)s及java方式的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇表單元素值獲取方式j(luò)s及java方式的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-10-10layui實(shí)現(xiàn)table加載的示例代碼
今天小編就為大家分享一篇layui實(shí)現(xiàn)table加載的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08javascript function、指針及內(nèi)置對(duì)象
該文摘自于匿名教程總結(jié),希望對(duì)初學(xué)js的同學(xué)有幫助,因?yàn)樗鉀Q了我學(xué)習(xí)js的眾多迷惑。。。2009-02-02javascript動(dòng)態(tài)添加表格數(shù)據(jù)行(ASP后臺(tái)數(shù)據(jù)庫(kù)保存例子)
本文,我將以一個(gè)類似的例子來(lái)做一個(gè)前臺(tái)用Javascript動(dòng)態(tài)添加數(shù)據(jù)項(xiàng),后臺(tái)保存到數(shù)據(jù)庫(kù)的例子。2010-05-05JS實(shí)現(xiàn)選中當(dāng)前菜單后高亮顯示的導(dǎo)航條效果
這篇文章主要介紹了JS實(shí)現(xiàn)選中當(dāng)前菜單后高亮顯示的導(dǎo)航條效果,涉及JavaScript針對(duì)頁(yè)面元素的遍歷及樣式動(dòng)態(tài)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-10-10JS實(shí)現(xiàn)網(wǎng)頁(yè)煙花動(dòng)畫效果
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)網(wǎng)頁(yè)煙花動(dòng)畫效果,點(diǎn)擊鼠標(biāo)煙花向四周擴(kuò)散,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03