Vue 与 Electron 结合开发桌面应用

news/2025/2/2 19:54:08 标签: vue.js, electron, 桌面应用

1. 引言

  • 1.1 什么是 Electron?
    • Electron 是一个使用 JavaScript、HTML 和 CSS 构建跨平台桌面应用程序的框架。它结合了 Chromium 渲染引擎和 Node.js 运行时,使得开发者可以使用 Web 技术创建原生桌面应用
  • 1.2 为什么选择 Vue.js 和 Electron?
    • Vue.js 是一个渐进式 JavaScript 框架,易于上手且功能强大。结合 Electron,可以快速构建出美观且功能丰富的桌面应用
  • 1.3 目标读者
    • 本文适合对 Vue.js 有一定了解,并希望学习如何使用 Electron 开发桌面应用的开发者。

2. 环境准备

  • 2.1 安装 Node.js 和 npm

    • 访问 Node.js 官网 下载并安装最新版本的 Node.js,npm 会随 Node.js 一起安装。
  • 2.2 安装 Vue CLI

    npm install -g @vue/cli
    
  • 2.3 安装 Electron

    npm install -g electron
    

3. 创建 Vue 项目

  • 3.1 使用 Vue CLI 创建项目

    vue create my-electron-app
    cd my-electron-app
    
  • 3.2 项目结构介绍

    • public:存放静态资源文件。
    • src:存放源代码文件。
    • package.json:项目配置文件。
  • 3.3 运行 Vue 项目

    npm run serve
    

4. 集成 Electron

  • 4.1 初始化 Electron 项目

    • 在 Vue 项目根目录下创建 main.js 文件。
    const {
          app, BrowserWindow } = require('electron');
    const path = require('path');
    
    function createWindow() {
         
      const win = new BrowserWindow({
         
        width: 800,
        height: 600,
        webPreferences: {
         
          preload: path.join(__dirname, 'preload.js'),
          nodeIntegration: true,
          contextIsolation: false,
        },
      });
    
      win.loadURL('http://localhost:8080');
    }
    
    app.whenReady().then(() => {
         
      createWindow();
    
      app.on('activate', () => {
         
        if (BrowserWindow.getAllWindows().length === 0) {
         
          createWindow();
        }
      });
    });
    
    app.on('window-all-closed', () => {
         
      if (process.platform !== 'darwin') {
         
        app.quit();
      }
    });
    
  • 4.2 创建主进程文件(main.js)

    • 上面已经创建了 main.js 文件,它是 Electron 应用的入口文件。
  • 4.3 配置 Electron 打包工具

    • package.json 中添加 Electron 的启动脚本。
    "scripts": {
         
      "serve": "vue-cli-service serve",
      "build": "vue-cli-service build",
      "lint": "vue-cli-service lint",
      "electron:serve": "electron ."
    }
    
  • 4.4 运行 Electron 应用

    npm run serve
    npm run electron:serve
    

5. 项目结构优化

  • 5.1 分离主进程和渲染进程代码

    • 将主进程和渲染进程的代码分开,使项目结构更清晰。
    • 主进程:main.js
    • 渲染进程:Vue 项目
  • 5.2 使用 Webpack 打包 Electron 应用

    npm install --save-dev electron-builder
    vue add electron-builder
    
  • 5.3 配置 Vue CLI 与 Electron 的集成

    • vue.config.js 中配置打包选项。
    module.exports = {
         
      pluginOptions: {
         
        electronBuilder: {
         
          mainProcessFile: 'src/main.js',
          rendererProcessFile: 'src/renderer.js',
          nodeIntegration: true,
          contextIsolation: 

http://www.niftyadmin.cn/n/5840257.html

相关文章

架构技能(四):需求分析

需求分析,即分析需求,分析软件用户需要解决的问题。 需求分析的下一环节是软件的整体架构设计,需求是输入,架构是输出,需求决定了架构。 决定架构的是软件的所有需求吗?肯定不是,真正决定架构…

WebForms DataList 深入解析

WebForms DataList 深入解析 引言 在Web开发领域,控件是构建用户界面(UI)的核心组件。ASP.NET WebForms框架提供了丰富的控件,其中DataList控件是一个灵活且强大的数据绑定控件。本文将深入探讨WebForms DataList控件的功能、用法以及在实际开发中的应用。 DataList控件…

JavaScript 入门教程

JavaScript 入门教程 JavaScript 入门教程引言学习 JavaScript 的好处常见的 JavaScript 框架和库 安装开发环境下载并安装 Node.js 和 npm安装常用开发工具(如 VS Code)配置本地开发环境 基础语法入门数据类型变量与常量运算符算术运算符比较运算符 条件…

model.eval() model.train()

本文由AI生成 在 PyTorch 中,model.eval() 是一个非常重要的操作,它将模型的模式切换为评估模式(evaluation mode)。这与训练模式(training mode)有所不同。在不同模式下,模型的行为会有所变化&…

LeetCode:279.完全平方数

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的! 代码随想录 LeetCode:279.完全平方数 给你一个整数 n ,返回 和为 n 的完全平方数的最少数量 。 完全平方数 是一个整…

【Java异步编程】CompletableFuture实现:异步任务的串行执行

文章目录 一. thenApply():转换计算结果1. 一个线程中执行或多个线程中执行2. 使用场景说明 二. thenRun():执行无返回值的操作1. 语法说明2. 使用场景说明 三. thenAccept():消费计算结果1. 语法说明a. 前后任务是否在一个线程中执行b. 要点…

基于 STM32 的智能电梯控制系统

1. 引言 随着城市化进程的加速,高层建筑日益增多,电梯作为垂直交通工具的重要性愈发凸显。传统电梯控制系统在运行效率、安全性和智能化程度上已难以满足现代需求。智能电梯控制系统能够实时监测电梯的运行状态、乘客需求,并根据这些信息优化…

C++中的析构器(Destructor)(也称为析构函数)

在C中,析构器(Destructor)也称为析构函数,它是一种特殊的成员函数,用于在对象销毁时进行资源清理工作。以下是关于C析构器的详细介绍: 析构函数的特点 名称与类名相同,但前面有一个波浪号 ~&a…