使用electron-vite创建桌面应用

使用electron-vite创建桌面应用

一、框架搭建

官网地址https://cn.electron-vite.org

bash 复制代码
npm create @quick-start/electron@latest

按步骤操作即可

二、项目目录

1、main 主进程窗口:存放窗口代码

2、preload 预加载模块:用于窗口与页面间沟通的桥梁,增加可靠性

3、renderer渲染模块:主要存放前端页面代码

三、preload.js解读

官网对应位置:https://www.electronjs.org/zh/docs/latest/api/context-bridge

1、在preload/index.js中定义预加载信息

bash 复制代码
import { contextBridge,ipcRenderer } from 'electron'
if (process.contextIsolated) {
  try {
    contextBridge.exposeInMainWorld('mytest', {
       //当前方法可以在渲染模块通过 window.mytest.doThing 进行调用
        doThing: () => ipcRenderer.send('mqtt_data')
    })
  } catch (error) {
    console.error(error)
  }
} else {
  window.mytest= {
       //兼容问题
        doThing: () => ipcRenderer.send('mqtt_data')
    }
}

2、在渲染模块中进行调用

bash 复制代码
<script setup>
    function handleClick() {
       window.mytest.doThing()
    }
</script>

<template>
  <ul class="versions">
    <button @click="handleClick">按钮</button>
  </ul>
</template>

3、在主进程中进行接收

bash 复制代码
import { ipcMain } from 'electron'
ipcMain.on('mqtt_data', () => console.log(666))

效果:

相关推荐
吃饺子不吃馅9 分钟前
深感一事无成,还是踏踏实实做点东西吧
前端·svg·图形学
90后的晨仔38 分钟前
Mac 上配置多个 Gitee 账号的完整教程
前端·后端
少年阿闯~~1 小时前
CSS——实现盒子在页面居中
前端·css·html
开发者小天1 小时前
uniapp中封装底部跳转方法
前端·javascript·uni-app
阿波罗尼亚1 小时前
复杂查询:直接查询/子查询/视图/CTE
java·前端·数据库
正义的大古2 小时前
OpenLayers地图交互 -- 章节九:拖拽框交互详解
前端·vue.js·openlayers
三十_A2 小时前
【实录】使用 Verdaccio 从零搭建私有 npm 仓库(含完整步骤及避坑指南)
前端·npm·node.js
huangql5202 小时前
从零到一打造前端内存监控 SDK,并发布到 npm ——基于 TypeScript + Vite + ECharts的解决方案
前端·typescript·echarts
weixin_456904272 小时前
离线下载npm包
前端·npm·node.js
低代码布道师2 小时前
少儿舞蹈小程序(19)地址列表功能实现及默认地址逻辑
前端·低代码·小程序