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

效果:

相关推荐
霍理迪15 分钟前
Vue的响应式和生命周期
前端·javascript·vue.js
李剑一20 分钟前
别再瞎写了!Cesium 模型 360° 环绕,4 套源码全公开,项目直接用
前端
小码哥_常37 分钟前
Android消息机制:Handler、Looper和Message的深度剖析
前端
小码哥_常40 分钟前
安卓开发新姿势:文件Picker全攻略,无痛适配不再难
前端
happymaker06261 小时前
web前端学习日记——DAY04
前端·学习
发现一只大呆瓜1 小时前
React-路由监听 / 跳转 / 守卫全攻略(附实战代码)
前端·react.js·面试
swipe2 小时前
为什么 RAG 一定离不开向量检索:从文档向量化到语义搜索的工程实现
前端·llm·agent
OpenTiny社区2 小时前
AI-Extension:让 AI 真的「看得到、动得了」你的浏览器
前端·ai编程·mcp
IT_陈寒2 小时前
Redis缓存击穿:3个鲜为人知的防御策略,90%开发者都忽略了!
前端·人工智能·后端
竹林8183 小时前
在Web3前端用Node.js子进程批量校验钱包,我踩了这些性能与安全的坑
javascript·node.js