Electron桌面应用聊天(续)

2026.4.1

2026.4.10补充

一.Day.js

与时间格式相关的用day.js

安装 | Day.js中文网

复制代码
npm install dayjs --save

二.Omit

Omit 是 TypeScript 内置的泛型工具类型,作用是从一个类型中「剔除」指定的属性,生成一个新的类型。

语法与原理

复制代码
Omit<Type, Keys>
  • Type:你要操作的原始类型 (比如你的 MessageProps

  • Keys:你要剔除的属性名 (可以是单个属性,也可以是联合类型 'a' | 'b'

  • 最终返回一个剔除了指定属性后的新类型

三.进程间的通信(IPC)

渲染进程将问题连带着他的id等信息,传入主进程。在主进程调用对应的大模型,最后将结果又传回给渲染进程。

具体可查阅官方文档 进程间通信 | Electron

1.渲染进程 ---> 主进程

(1)渲染进程发送消息ipcRenderer.send

ipcRenderer.send(channel, data)

已经成功拿到newMessageId ,lastQuestion, provider.name, conversation.selectModel

可以进行发送:要把类型手动添加到window上去。

创建interface.d.ts,(在window上面加上electronAPI方法)

preload.ts中(在electron上面加上startChat方法)

conversation.vue(使用startChat方法)

type.ts

(2)主进程接收消息ipcMain.on

ipcMain.on(channel, (event, ...args) => {}

在main.ts中接收来自渲染进程的数据

可在终端查看,发现已成功打印

2.主进程 ----> 渲染进程

(1)主进程处理逻辑mainWindow.webContents.send

mainWindow.webContents.send('xxx', content);

上一步骤主进程已经拿到渲染进程的providerName, content, messageId, selectedModel。在这里就可以用拿到的数据,调用大模型,返回结果。又发送给渲染进程。

main.ts中

(2)渲染进程接收数据 ipcRenderer.on

发送的名字叫upload-message

proload.ts

给IElectronAPI加一个方法叫onUpdateMessage

interface.d.ts中

Conversation.vue就可以拿到大模型返回的数据了

可在控制台成功打印

(3)将数据展示到页面上

Conversation.vue

如图,成功返回。

【补充知识】

1.Electron 主进程 / 渲染进程区分:

  • 主进程(main.ts/main.js):Node.js 环境,负责窗口管理、IPC 通信,不能直接写 DOM 代码。

  • 渲染进程(.vue 文件):浏览器环境,支持 TS/JS,负责页面渲染,不能直接访问 Node.js API(需要通过 preload 桥接)。

2.TypeScript 类型的本质:

  • 所有 <> 包裹的类型语法(如 Omit<>data: Type)只在编译阶段生效,绝对不能出现在运行时的赋值语句中。

3.Electron IPC 通信规范:

1.渲染进程发送:ipcRenderer.send(channel, data)

2.主进程监听:ipcMain.on(channel, (event, ...args) => {}

中间靠proload.ts中的contextBridge桥接。

相关推荐
代码搬运媛6 小时前
Jest 测试框架详解与实现指南
前端
counterxing6 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq7 小时前
windows下nginx的安装
linux·服务器·前端
之歆7 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜7 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108087 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong7 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
kyriewen9 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm9 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy10 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程