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

效果:

相关推荐
前端Hardy5 分钟前
Python是怎么将Vue项目打包成桌面端应用程序的?看这篇就够了
前端·javascript·python
Spider_Man17 分钟前
物料区的“超市大冒险”:组件、遥控器与快乐星球的奇遇记 🛒🦄
前端·低代码·typescript
uppp»18 分钟前
echarts在前后端分离项目中的实践与应用
前端·javascript·echarts
之梦20 分钟前
Electron + Vue3开源跨平台壁纸工具实战(九)子进程服务(2)
前端·electron
三小河20 分钟前
css 中 inset属性 以及简单实现spinner
前端
小趴菜_21 分钟前
手把手教你用 Vue3 + LogicFlow 打造流程编排系统
前端·vue.js
MapleWan3206322 分钟前
关于统一地图组件的一些实践与思考
前端·开源
袁煦丞23 分钟前
Bitwarden+cpolar让隐私真正属于自己:cpolar内网穿透实验室第516个成功挑战
前端·程序员·远程工作
前端灵派派24 分钟前
electron窗口管理封装和页面通讯
前端·electron
木浔24 分钟前
SortableJS API 文档
前端·javascript