前端小周
前端小周
  • 发布:2023-12-15 15:25
  • 更新:2023-12-15 15:58
  • 阅读:279

web-view 可以实现h5向h5通讯吗?

分类:uni-app

App端是Vue3+nvue

代码<view :key="pageUrl">
<web-view ref="webviewRef" :style="{height:${windowHeight}px}" :webview-styles="webviewStyles" v-if="pageUrl" @onPostMessage="onPostMessage" @message="onPostMessage" :src="pageUrl" class="webView"></web-view>
</view>

const webviewRef = ref(null)
onLoad((op) => {
uni.$off('ws');
uni.$on('ws', (data) => {
nextTick(() => {
webviewRef.value.evalJs(pushMessage('${data}'))
})
})
})

H5是uniapp的vue3项目

onLaunch: function() {
window.pushMessage= function(data){
uni.$emit('ws', JSON.parse(data))
}
},

现在已经实现了App和H5的双向通讯 但是在调试中好麻烦呀 可以实现H5向webview通讯吗?
在浏览器运行APP项目中webviewRef.value.evalJs(pushMessage('${data}'))报错Uncaught (in promise) TypeError: webviewRef.value.evalJs is not a function
at playerPk.nvue:41:24

2023-12-15 15:25 负责人:无 分享
已邀请:
前端小周

前端小周 (作者) - 时间就是金钱,而编程就是时间。

已经实现

app代码

uni.$off('ws');
uni.$on('ws', (data) => {
nextTick(() => {
// #ifdef APP-PLUS
webviewRef.value.evalJs(pushMessage('${data}'))
// #endif
// #ifdef H5
const iframe = window.frames['0']; // 替换成你的 WebView ID
iframe.postMessage(data, '*');
// #endif
})
})

webview代码
onLaunch: function() {
window.pushMessage= function(data){
uni.$emit('ws', JSON.parse(data))
}
window.addEventListener("message", function(event) {
uni.$emit('ws', JSON.parse(event.data))
}, false);
},

前端小周

前端小周 (作者) - 时间就是金钱,而编程就是时间。

const iframe = window.frames['0']; // 替换成你的 WebView ID 现在ID我写死成0了 有没有优雅的方案?

要回复问题请先登录注册