uni-app之webview通信實(shí)現(xiàn)方法示例
1 背景
在uni-app開發(fā)中,常見的一種場景是主應(yīng)用通過web-view組件加載子應(yīng)用的H5頁面。為便于描述,我們將主應(yīng)用稱為App,子應(yīng)用稱為H5站點(diǎn)。兩者均采用uni-app+Vue技術(shù)棧:主應(yīng)用通過HBuilderX云打包生成原生App(如Android的APK包),子應(yīng)用則通過HBuilderX發(fā)布為H5站點(diǎn)。當(dāng)主應(yīng)用加載H5頁面時,web-view會占據(jù)整個手機(jī)屏幕。此時,若需通過物理按鍵或H5頁面的返回按鈕返回主應(yīng)用,則需實(shí)現(xiàn)應(yīng)用間通信,由H5站點(diǎn)向主應(yīng)用發(fā)送關(guān)閉web-view實(shí)例的請求。
2 技術(shù)方案
經(jīng)過分析,我確定了兩種可行的技術(shù)方案。第一種方案利用web-view組件的消息機(jī)制:子應(yīng)用通過調(diào)用postMessage向主應(yīng)用發(fā)送消息,主應(yīng)用監(jiān)聽message事件,并在消息處理函數(shù)中執(zhí)行web-view的關(guān)閉操作。第二種方案則采用服務(wù)器中轉(zhuǎn)機(jī)制:主應(yīng)用和子應(yīng)用均通過WebSocket連接至中轉(zhuǎn)服務(wù)器,實(shí)現(xiàn)命令的發(fā)送與接收。相較而言,第二種方案實(shí)現(xiàn)復(fù)雜度較高,且易受網(wǎng)絡(luò)環(huán)境影響。因此,本文將采用第一種方案進(jìn)行實(shí)現(xiàn)。
3 實(shí)現(xiàn)
3.1 子應(yīng)用實(shí)現(xiàn)
- 下載uni.webview.1.5.6.js
在子項(xiàng)目中,下載uni.webview.js,我使用的是uni.webview.1.5.6.js,下載地址為:
https://gitcode.net/dcloud/uni-app/-/raw/dev/dist/uni.webview.1.5.6.js
將下載完成的uni.webview.1.5.6.js文件復(fù)制到項(xiàng)目的目錄/static/js/目錄下(如果目錄不存在,則可以手動創(chuàng)建這個目錄)。
- 引用
修改main.js, 添加對uni.webview.1.5.6.js的引用:
import '/static/js/uni.webview.1.5.6.js'
- 調(diào)用postMessage
在需要返回主應(yīng)用的地方,添加如下代碼
if(uni.webView) { console.log("支持uni.webview", uni.webView); uni.webView.postMessage({ data: { action: 'backToPlatform' } }); } else { console.log("不支持uni.webview"); }
3.2 主應(yīng)用實(shí)現(xiàn)
- 模版
<web-view :embed="true" :src="imViewUrl" @message="handleMessage" />
- js
export default { //其他代碼 methods: { handleMessage(e) { if(e && e.detail && e.detail.data && e.detail.data.length > 0) { const { action } = e.detail.data[0]; if(action == 'backToPlatform') { //在這里,我們可以通過顯隱條件或refs對象的操作來關(guān)閉web-view } } }, } //其他代碼
3.3 主應(yīng)用發(fā)送消息到H5
- app端
var currentWebview = that.$parent.$scope.$getAppWebview() currentWebview.children()[0].evalJS(`onMicrophonePermResult(${res ? 'true' : 'false'})`);
- h5段
mounted() { // 將方法掛載到 window,供主應(yīng)用調(diào)用 window.onMicrophonePermResult = (result) => { console.log("onMicrophonePermResult result=", result) }; },
總結(jié)
到此這篇關(guān)于uni-app之webview通信實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)uni-app webview通信內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue 實(shí)現(xiàn)v-for循環(huán)的時候更改 class的樣式名稱
這篇文章主要介紹了Vue 實(shí)現(xiàn)v-for循環(huán)的時候更改 class的樣式名稱,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07解決VMware中vmware-vmx.exe進(jìn)程無法關(guān)閉以及死機(jī)等問題
這篇文章主要介紹了解決VMware中vmware-vmx.exe進(jìn)程無法關(guān)閉以及死機(jī)等問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-06-06vue本地打開build后生成的dist文件夾index.html問題
這篇文章主要介紹了vue本地打開build后生成的dist文件夾index.html問題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友參考下吧2019-09-09vue?MVVM雙向綁定實(shí)例詳解(數(shù)據(jù)劫持+發(fā)布者-訂閱者模式)
使用vue也好有一段時間了,也算對其雙向綁定原理也有了解個大概,這篇文章主要給大家介紹了關(guān)于vue?MVVM雙向綁定(數(shù)據(jù)劫持+發(fā)布者-訂閱者模式)的相關(guān)資料,需要的朋友可以參考下2022-03-03electron?dialog.showMessageBox的使用案例
Electron?Dialog?模塊提供了api來展示原生的系統(tǒng)對話框,本文主要介紹了electron?dialog.showMessageBox的使用案例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08