Vue 3 和 Electron 来构建一个桌面端应用

server/2025/1/12 11:35:40/

我们将使用 Vue 3 和 Electron 来构建一个桌面端应用,该应用可以通过 Websocket 与服务器进行通信,并实现心跳检测、客户端上线、获取资产信息以及修改资产状态的功能。以下是实现步骤的概述:

  1. 项目结构:创建一个 Vue 3 项目,并集成 Electron。
  2. Websocket 连接:在 Vue 组件中建立 Websocket 连接,并处理心跳检测、客户端上线、获取资产信息和修改资产状态的逻辑。
  3. UI 设计:设计简单的 UI 界面,用于展示资产信息和操作按钮。
  4. Electron 打包:使用 Electron 将 Vue 项目打包为桌面应用。

详细步骤

1. 项目结构

我们已经有一个 Vue 3 项目,接下来需要安装 Electron 和其他必要的依赖。

npm install electron --save-dev
npm install vue-router
npm install websocket
npm install axios

在 src 目录下创建以下文件:

  • src/main.js:Vue 应用的入口文件。
  • src/electron.js:Electron 的主进程文件。
  • src/router/index.js:Vue Router 的配置文件。
  • src/components/Home.vue:主页面组件。
2. Websocket 连接

在 src/components/Home.vue 中,我们将实现 Websocket 连接和相关业务逻辑。

<template><div><h1>资产管理系统</h1><button @click="pingServer">Ping 服务器</button><button @click="clientOnline">客户端上线</button><button @click="getAssetInfo">获取资产信息</button><button @click="updateAssetStatus">修改资产状态</button><div v-if="assetInfo"><h2>资产信息</h2><pre>{{ assetInfo }}</pre></div></div>
</template><script>
import { ref } from 'vue';
import { w3cwebsocket as W3CWebSocket } from 'websocket';const client = new W3CWebSocket('ws://192.168.5.145:8899/iothub');export default {setup() {const assetInfo = ref(null);client.onopen = () => {console.log('WebSocket Client Connected');};client.onmessage = (message) => {const data = JSON.parse(message.data);console.log('Received: ', data);if (data.code === '0') {assetInfo.value = data.data;} else {alert(data.msg);}};const pingServer = () => {client.send(JSON.stringify({ type: 'ping' }));};const clientOnline = () => {client.send(JSON.stringify({ type: 'up', from: 'doorDev', uid: 'unique-id-123' }));};const getAssetInfo = () => {const epc = prompt('请输入资产 EPC');if (epc) {client.send(JSON.stringify({type: 'send',from: 'doorDev',uid: 'unique-id-123',msg: {method: 'getAssetByEpc',passType: 'out',epc: epc}}));}};const updateAssetStatus = () => {const assetId = prompt('请输入资产 ID');if (assetId) {client.send(JSON.stringify({type: 'send',from: 'doorDev',uid: 'unique-id-123',msg: {method: 'updateAssetStatus',assetId: assetId}}));}};return {pingServer,clientOnline,getAssetInfo,updateAssetStatus,assetInfo};}
};
</script><style>
/* 这里可以添加一些简单的样式 */
</style>
3. Vue Router 配置

在 src/router/index.js 中配置路由:

import { createRouter, createWebHistory } from 'vue-router';
import Home from '../components/Home.vue';const routes = [{path: '/',name: 'Home',component: Home}
];const router = createRouter({history: createWebHistory(),routes
});export default router;
4. Electron 主进程

在 src/electron.js 中配置 Electron 主进程:

const { app, BrowserWindow } = require('electron');
const path = require('path');function createWindow() {const mainWindow = new BrowserWindow({width: 800,height: 600,webPreferences: {preload: path.join(__dirname, 'preload.js'),nodeIntegration: true,contextIsolation: false}});mainWindow.loadURL('http://localhost:8080');
}app.whenReady().then(() => {createWindow();app.on('activate', function () {if (BrowserWindow.getAllWindows().length === 0) createWindow();});
});app.on('window-all-closed', function () {if (process.platform !== 'darwin') app.quit();
});
5. 修改 package.json

在 package.json 中添加 Electron 启动脚本:

{"scripts": {"serve": "vue-cli-service serve","build": "vue-cli-service build","lint": "vue-cli-service lint","electron:serve": "vue-cli-service serve & electron ."}
}
6. 运行项目

使用以下命令启动项目:

npm run electron:serve


http://www.ppmy.cn/server/157752.html

相关文章

设计模式 行为型 备忘录模式(Memento Pattern)与 常见技术框架应用 解析

备忘录模式&#xff08;Memento Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许在不暴露对象内部细节的情况下保存和恢复对象的内部状态。这种模式的核心思想是将对象的状态保存在一个独立的备忘录对象中&#xff0c;以便在需要时可以恢复到之前的状态。 一、核心…

Redis 性能优化 18招

前言 Redis在我们的日常开发工作中&#xff0c;使用频率非常高&#xff0c;已经变成了必不可少的技术之一。 Redis的使用场景也很多。 比如&#xff1a;保存用户登录态&#xff0c;做限流&#xff0c;做分布式锁&#xff0c;做缓存提升数据访问速度等等。 那么问题来了&…

Copilot 和 Windsurf哪个更适合于.netcore开发

要判断 Copilot 和 Windsurf 哪个更适合 .NET Core 开发&#xff0c;我们可以从以下几个维度进行比较&#xff1a; 1. 开发定位与目标 Copilot&#xff1a;由 GitHub 和 OpenAI 联合推出&#xff0c;旨在通过 AI 辅助代码开发&#xff0c;提供智能代码补全、生成、以及上下文理…

spark汇总

目录 描述运行模式1. Windows模式代码示例 2. Local模式3. Standalone模式 RDD描述特性RDD创建代码示例&#xff08;并行化创建&#xff09;代码示例&#xff08;读取外部数据&#xff09;代码示例&#xff08;读取目录下的所有文件&#xff09; 算子DAGSparkSQLSparkStreaming…

React中createRoot函数原理解读——Element对象与Fiber对象、FiberRootNode与HostRootNode

【2024最新版】React18 核心源码分析教程&#xff08;全61集&#xff09; Element对象与Fiber对象 在 React 中&#xff0c;Element 对象 和 Fiber 对象 是核心概念&#xff0c;用于实现 React 的高效渲染和更新机制。以下是它们的详细解读&#xff1a; 1. Element 对象 定…

如何从 Keycloak 的 keycloak-themes.jar 中提取原生主题并自定义设置

言简意赅的讲解keycloak-themes.jar解决的痛点 在部署和自定义 Keycloak主题 时你可能遇到了没有原生主题代码的难点&#xff0c;后续在Keycloak官方项目中获取原生主题文件还是无法找到主题源码。 下面这篇文章将向你展示&#xff0c;在某些 Keycloak 发行版本或特定部署方式…

Word快捷键汇总

Word 中的键盘快捷方式 - Microsoft 支持 1 常用到的快捷键 执行的操作 按 打开文档。 CtrlO 创建新文档。 CtrlN 保存文档。 CtrlS 关闭文档 CtrlW 将所选内容剪切到剪贴板中。 CtrlX 将所选内容复制到剪贴板中。 CtrlC 粘贴剪贴板的内容。 CtrlV 选择所有文档…

MXNet 入门指南:高效深度学习框架的简要介绍

MXNet 是一个开源深度学习框架&#xff0c;以其高性能和灵活性著称。它支持多种编程语言&#xff0c;如 Python、R、Scala、Julia、C 等&#xff0c;并具有分布式计算和自动求导机制。MXNet 曾被 Amazon 选为其 AWS 平台上的深度学习框架之一。 MXNet 特点&#xff1a; 多语言…