7.electron之渲染线程发送事件,主进程监听事件

如果可以实现记得点赞分享,谢谢老铁~

Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 Electron 将 Chromium 和

Node.js 嵌入到了一个二进制文件中,因此它允许你仅需一个代码仓库,就可以撰写支持 Windows、macOS 和 Linux

的跨平台应用。

1.项目效果, 我的目的是打开一个弹窗,点击按钮打开文件管理器,且只能选中文件夹而不是文件的路径

2.这里要分两个进程说,先说渲染进程,也就是我们的业务逻辑层

index.tsx

js 复制代码
import { Button } from 'antd';
import { useState } from 'react';
import { EllipsisOutlined } from '@ant-design/icons';

export default () => {
  const [inputPath, setInputPath] = useState('')
  const openFileDialog = () => {
    // 发送事件到主进程
    try {
      window.ipcRenderer.send('buttonClicked');
      // 监听主进程回复的选择的文件路径
      window.ipcRenderer.on('selected-file', (event, filePaths) => {
        if (filePaths) {
          setInputPath(filePaths)
        }
      });
    } catch (error) {
      console.log('web网页版不支持获取目录,请在桌面端操作')
    }

  };
  return (
    <div>
    	<Input value={inputPath} style={{ width: '92%' }} readOnly />
       <Button icon={<EllipsisOutlined onClick={openFileDialog} />} />
    <div/>
  );
};

上述代码块中,通过

powershell 复制代码
window.ipcRenderer.send('buttonClicked'); // 自定义事件名发送事件

PS:你肯定有个大大的疑问 window.ipcRenderer 这个哪里来的?这个是
主进程里面的预加载js模块,作用在window全局里了,不懂得请点击 上一篇文章
《6.electron之上下文隔离,预加载JS脚本》

3.现在来说一下 主进程是如何监听事件的

electron.js

js 复制代码
const {
    dialog,
    ipcMain,
} = require("electron");
   // 监听来自渲染进程的事件,这里的 'buttonClicked' 就是渲染进程中的自定义名字。
    ipcMain.on('buttonClicked', (event, arg) => {
        // 在这里处理事件的逻辑
        dialog.showOpenDialog(mainWindow, {
            properties: ['openDirectory'], // openDirectory 代表文件夹
            title: '选择文件夹',
            buttonLabel: '选择',
        }).then(result => {
            if (!result.canceled && result.filePaths.length > 0) {
                const selectedFolder = result.filePaths[0];
                // PS: 发送选择的文件路径给渲染进程
                event.reply('selected-file', selectedFolder);
            }
        }).catch(err => {
            console.error(err);
        });
    });

4.运行以下命令来构建React项目:

powershell 复制代码
npm run build

PS:打开build目录下的index.html文件,发现是一片空白😱,F12一下,发现是资源路径不对。解决方案是在package.json中添加"homepage": "./"。添加之后再进行build,打开index.html,就能看到正常页面了。

5.运行以下命令来启动Electron应用程序:

powershell 复制代码
npm run electron:dev

这将启动Electron应用程序,并加载React应用程序的构建文件。

6.运行以下命令来打包Electron应用程序:

powershell 复制代码
npm run electron:build

收工!谢谢老铁们的点赞收藏~

相关推荐
web打印社区6 小时前
2026最新Web静默打印解决方案,无插件无预览,完美替代Lodop
前端·javascript·vue.js·electron·pdf
垚森7 小时前
VibePlayer v1.3.3 更新:全新 Logo + 修复音乐库高亮 Bug
ai·electron
一叶飘零晋10 小时前
【(一)Electron 使用之如何用vite+vue3搭建初始框架】
前端·javascript·electron
天天进步201513 小时前
魔音漫创源码解析:架构总览:Electron 30 + React 18 + Zustand,构建桌面级影视生产工具
react.js·架构·electron
一叶飘零晋14 小时前
【(二)Electron 使用之常用技巧】
javascript·electron·ecmascript
web打印社区2 天前
[特殊字符] 开源好物:web-print-pdf,让 Web 打印像调用接口一样简单!
前端·javascript·vue.js·electron
森总20203 天前
Electron 实战:utilityProcess 服务脚本热更新、用户目录优先启动与 asar 依赖解析
electron
政采云技术3 天前
从投标客户端看 Electron + React 工程化实践
electron
得想办法娶到那个女人3 天前
Vite + Vue 项目打包为 Electron 桌面应用 完整指南
前端·vue.js·electron
李李李勃谦3 天前
Vue3 + Electron + OpenHarmony 跨平台实战:从架构设计到 Markdown 编辑器完整实现
javascript·华为·electron·编辑器·harmonyos