uni-app之webview通信實(shí)現(xiàn)方法示例
1 背景
在uni-app開發(fā)中,常見的一種場(chǎng)景是主應(yīng)用通過(guò)web-view組件加載子應(yīng)用的H5頁(yè)面。為便于描述,我們將主應(yīng)用稱為App,子應(yīng)用稱為H5站點(diǎn)。兩者均采用uni-app+Vue技術(shù)棧:主應(yīng)用通過(guò)HBuilderX云打包生成原生App(如Android的APK包),子應(yīng)用則通過(guò)HBuilderX發(fā)布為H5站點(diǎn)。當(dāng)主應(yīng)用加載H5頁(yè)面時(shí),web-view會(huì)占據(jù)整個(gè)手機(jī)屏幕。此時(shí),若需通過(guò)物理按鍵或H5頁(yè)面的返回按鈕返回主應(yīng)用,則需實(shí)現(xiàn)應(yīng)用間通信,由H5站點(diǎn)向主應(yīng)用發(fā)送關(guān)閉web-view實(shí)例的請(qǐng)求。
2 技術(shù)方案
經(jīng)過(guò)分析,我確定了兩種可行的技術(shù)方案。第一種方案利用web-view組件的消息機(jī)制:子應(yīng)用通過(guò)調(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)用均通過(guò)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/目錄下(如果目錄不存在,則可以手動(dòng)創(chuàng)建這個(gè)目錄)。
- 引用
修改main.js, 添加對(duì)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') {
//在這里,我們可以通過(guò)顯隱條件或refs對(duì)象的操作來(lái)關(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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue 實(shí)現(xiàn)v-for循環(huán)的時(shí)候更改 class的樣式名稱
這篇文章主要介紹了Vue 實(shí)現(xiàn)v-for循環(huán)的時(shí)候更改 class的樣式名稱,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07
springboot?vue接口測(cè)試前端模塊樹和接口列表
這篇文章主要為大家介紹了springboot?vue接口測(cè)試前端模塊樹和接口列表,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
解決VMware中vmware-vmx.exe進(jìn)程無(wú)法關(guān)閉以及死機(jī)等問(wèn)題
這篇文章主要介紹了解決VMware中vmware-vmx.exe進(jìn)程無(wú)法關(guān)閉以及死機(jī)等問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
vue本地打開build后生成的dist文件夾index.html問(wèn)題
這篇文章主要介紹了vue本地打開build后生成的dist文件夾index.html問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2019-09-09
解決vue scoped scss 無(wú)效的問(wèn)題
這篇文章主要介紹了解決vue scoped scss 無(wú)效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
vue?MVVM雙向綁定實(shí)例詳解(數(shù)據(jù)劫持+發(fā)布者-訂閱者模式)
使用vue也好有一段時(shí)間了,也算對(duì)其雙向綁定原理也有了解個(gè)大概,這篇文章主要給大家介紹了關(guān)于vue?MVVM雙向綁定(數(shù)據(jù)劫持+發(fā)布者-訂閱者模式)的相關(guān)資料,需要的朋友可以參考下2022-03-03
VUE實(shí)現(xiàn)一個(gè)分頁(yè)組件的示例
本篇文章主要介紹了VUE實(shí)現(xiàn)一個(gè)分頁(yè)組件的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
electron?dialog.showMessageBox的使用案例
Electron?Dialog?模塊提供了api來(lái)展示原生的系統(tǒng)對(duì)話框,本文主要介紹了electron?dialog.showMessageBox的使用案例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08

