使用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))

效果:

相关推荐
abcy071213几秒前
python pandas csv异步后台清洗前端优先返回成功信息
前端·python·pandas
不会敲代码119 分钟前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
IT_陈寒24 分钟前
Vite这个坑我帮你踩了,动态导入居然这样才生效
前端·人工智能·后端
贩卖黄昏的熊26 分钟前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe27 分钟前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试
鹤鸣的日常35 分钟前
前端运行时动态环境变量方案
前端·react.js·docker·前端框架·vue·gitlab
Lee川35 分钟前
Event Loop 面试通关:从原理到口述再到实战
前端·面试
kyriewen1 小时前
手写 call、apply、bind:从原理到实现,附 3 个最容易忽略的边界情况
前端·javascript·面试
用户2181697049301 小时前
swift (三) 枚举 结构体 类
前端
胡萝卜术1 小时前
从内存视角重新认识 JavaScript 数据类型:一份深度学习笔记
前端·javascript·面试