electron+VUE Browserwindow与webview通信

仅做记录

前言:

electron+VUE+VITE框架,用的是VUE3.0

主进程定义:用于接收webview发送的消息

复制代码
ipcMain.on('MyWebviewMessage', (event, message) => {
  logger.info('收到webmsg=' + message)
  //转发给渲染进程
   
})

porelaod/webPreload.js定义

复制代码
const { contextBridge, ipcRenderer } = require('electron')

contextBridge.exposeInMainWorld('electronAPI', {
  send: (channel, data) => {
    ipcRenderer.send(channel, data)
  },
})

VUE文件中定义

复制代码
<template>
  <div class="XXX">
    <el-scrollbar height="98%">
      <webview
        id="webViewId"
        allowpopups
        :preload="preloadPath"
        :src="url"
      ></webview>
    </el-scrollbar>
  </div>
</template>

最关键的preloadpath

我在script中如下定义

复制代码
const preloadPath = ref<string>('')
复制代码
const filePath = await window.api.GetWebViewPreloadPath()
console.log('filePath=' + filePath)
preloadPath.value = `file:///${filePath}`

其中preloadPath需要以file:///开头的绝对路径

例如:file:///C:/porelaod/webPreload.js

可以使用注入JS方式来实现调用window.electronAPI.send('MyWebviewMessage')

例如:

//获取VUE中定义的webView中的id

const webview: any = document.getElementById('webViewId')

复制代码
onMounted(async () => {
webview?.addEventListener('dom-ready', () => {
  setTimeout(() => {
    // 打开webview devtools
    //webview.openDevTools()
    //注入JS
    webViewExecuteJS(webview)
  }, 500)
})
复制代码
function webViewExecuteJS(webview: any) {
window.electronAPI.send('MyWebviewMessage', '测试')
 }
const injectScript = `
  document.addEventListener('click', ${handleClick.toString()});
`
// 在webview中注入脚本
webview.executeJavaScript(injectScript)

需要注意的地方

1,porelaod注入的路径需要以file:///开头的绝对路径,如果不能保证 可以直接在vue中如下写法来进行测试

<template> <div class="XXX"> <el-scrollbar height="98%"> <webview id="webViewId" allowpopups :preload="file:///C:/porelaod/webPreload.js" :src="url" ></webview> </el-scrollbar> </div> </template>

2,通过

复制代码
webview.openDevTools()打开webview的控制台

附图

如果能看到webview控制台里面的命令:window.electronAPI 说明已经通信成功了,后面就可以自己实现自己的逻辑了

相关推荐
前端小趴菜052 小时前
React-React.memo-props比较机制
前端·javascript·react.js
RadiumAg5 小时前
记一道有趣的面试题
前端·javascript
yangzhi_emo5 小时前
ES6笔记2
开发语言·前端·javascript
yanlele5 小时前
我用爬虫抓取了 25 年 5 月掘金热门面试文章
前端·javascript·面试
烛阴6 小时前
void 0 的奥秘:解锁 JavaScript 中 undefined 的正确打开方式
前端·javascript
Hexene...6 小时前
【前端Vue】如何实现echarts图表根据父元素宽度自适应大小
前端·vue.js·echarts
初遇你时动了情7 小时前
腾讯地图 vue3 使用 封装 地图组件
javascript·vue.js·腾讯地图
dssxyz7 小时前
uniapp打包微信小程序主包过大问题_uniapp 微信小程序时主包太大和vendor.js过大
javascript·微信小程序·uni-app
华子w9089258597 小时前
基于 SpringBoot+VueJS 的农产品研究报告管理系统设计与实现
vue.js·spring boot·后端
ohMyGod_1239 小时前
React16,17,18,19新特性更新对比
前端·javascript·react.js