当前位置: 首页 > news >正文

凯叔讲故事网站谁做的中国广告网

凯叔讲故事网站谁做的,中国广告网,成都学校网站制作,bf域名免费注册最近在做一个C/S架构的项目预研 过程中遇到 Electron 与 Vue3 通讯的问题,费劲巴力的在网上找方案,发现都不理想,最终攻克之后,计划将过程写下来,供有需求的同学白嫖! 开始之前,先说一件重要的…

最近在做一个C/S架构的项目预研

过程中遇到 Electron 与 Vue3 通讯的问题,费劲巴力的在网上找方案,发现都不理想,最终攻克之后,计划将过程写下来,供有需求的同学白嫖!

开始之前,先说一件重要的事情:
看文档
看官方文档
一定要看官方文档

好,言归正传。
先说需求,我是做一个 C/S 架构的串口数据获取的需求预研。另外,项目组 Vue 人才较多,所以,期望后期可以接上 Vue。
因此,我的需求是:在 Vue 项目中,能够获取 串行端口 传递过来的数据。


目前系统和版本情况:

  • 电脑系统:Windows 11
  • Electron 版本:28.1.0
  • Vue 版本:3.4.21

有同学就说了,你 Vue 要获取串口信息,不是可以直接使用 Web Serial API 吗?
是的,Web Serial API 也是一个不错的选择,可是 B/S 架构下,Vue 是没办法获取到 串口的硬件信息的,目前这个 Web Serial API 还不太适用我们的项目需求。再者,预研嘛,技术储备多多益善!


今天先聊聊核心点,Electron 与 Vue3 通讯的问题,随后会写一篇详细的文章来记录具体步骤。

核心一

Electron 的 main.js 中,在合适的时机通过 send 发送相关信号和数据

示例代码:

mainWindow.webContents.send('serial-datas', data);

核心二

Electron 的 preload.js 中,完成上述操作的预加载

示例代码:

const { contextBridge, ipcRenderer } = require('electron')contextBridge.exposeInMainWorld('electronAPI', {onSerialDatas: (callback) => ipcRenderer.on('serial-datas', (_event, value) => callback(value))
})

注意,Electron 的 main.js 中要加载 preload.js 这个预加载文件,参考代码:

const createWindow = () => {mainWindow = new BrowserWindow({width: 1200,height: 600,webPreferences: {nodeIntegration: true,contextIsolation: true,preload: path.join(__dirname, '/preload.js')},})mainWindow.loadURL('http://localhost:5173')mainWindow.on('closed', function () {mainWindow = null;});
}

核心三

Vue 的合适位置,接收 Electron 发送过来的数据。

我这里直接封装了一个监听文件,在 Vue 的 main.js 文件中进行了引入

Vue 的 getPortsFromElectron.js 示例代码:

/*** 接收 electron 发送过来的数据*/
window.electronAPI.onSerialDatas((value) => {/*** 数据转换(value 为 Uint8Array 格式的数据):* 根据你接收到的具体数据格式,你可能需要进行更复杂的解析。* 这取决于你与设备之间的通信协议以及你发送和接收数据的方式。* 如果是 ASCII 编码的,你可以使用 TextDecoder 对象将 Uint8Array 转换为字符串*/const decoder = new TextDecoder('utf-8');const receivedString = decoder.decode(value);console.log(receivedString);
})

Vue 的 main.js 示例代码:

import { createApp } from 'vue'
import...import './utils/getPortsFromElectron'const app = createApp(App)
...

以上三处就是 IPC 通讯(Electron 与 Vue3 通讯)的核心所在,我的总结是:
Electron 中准备好,发送,Vue 中接收,三步对应即可!

以上信息是在各种查找无果的情况下,突然想起去官网看文档,果然找到了可行的方案!

核心内容记录至此,后续更新详细过程。

http://www.hrbkazy.com/news/55287.html

相关文章:

  • 在线网站软件免费下载安装初学seo网站推广需要怎么做
  • 外贸网站模板下载seo关键词搜索和优化
  • 高级网站开发培训价格网络关键词
  • 自我介绍网页制作htmlwindows优化大师怎么下载
  • 网站图片多 如何优化seo专业培训课程
  • 做调查赚钱靠谱的网站有哪些百度搜索数据查询
  • php部署网站直播:韩国vs加纳直播
  • wordpress采集器seo是什么软件
  • 建站优化一条龙海南乐秀同城群软件下载
  • 苏州市住房和城乡建设局网站首页制作网站模板
  • 国家卫生健康委人才交流中心网站小程序怎么开发
  • 哪个网站专门做快餐车seo资源网站排名
  • 东莞好的网站建设公司百度网盘官网下载
  • 如何做线上赌博的网站优化大师 win10下载
  • 青岛网站建设全包个人引流推广怎么做
  • 网站怎么做网盘河南网站推广
  • 上海做网站推荐网络优化器
  • 公司制作网站费用广东网站营销seo方案
  • 惠州网站建设制作推广培训机构推荐
  • 石家庄建设南大街小学网站乔拓云智能建站平台
  • 深圳有哪些做网站公司谷歌推广真有效果吗
  • 怎么让别人访问自己做的的网站东莞百度快速排名
  • 福州成人高考网站百度搜索风云榜人物
  • 大连免费建站模板网络营销的含义特点
  • 做徽商要做网站吗注册网站怎么注册
  • 网站框架图实训百度搜索引擎的总结
  • 毕设做网站什么主题比较好百度seo怎么操作
  • 政务网站集约化建设难点与建议关键词排名推广公司
  • 网络建设解决方案佛山seo外包平台
  • 办公室网络设计方案只要做好关键词优化