Electron + ts + vue3 + vite

  1. 正常搭建脚手架:npm create vite@latest 项目名称

  2. 安装electron的相关依赖:注:安装时终端url要项目名那一层

  3. 安装npm install electron -D

  4. 安装打包工具:npm install electron-builder -D

  5. 开发工具:npm install electron-devtools-installer -D

  6. 配置文件:npm install vite-plugin-electron -D,npm install vite-plugin-electron-renderer -D

  7. 在项目的根目录下新建electron-main文件夹,之后新建index.ts,配置如下:

    javascript 复制代码
    import { app, BrowserWindow } from "electron";
    import * as path from "path";
    
    // 本地启动的vue项目路径
    const vueProjectAddress = "http://localhost:5173"
    /**
     * 创建一个新的窗口
     */
    const createWindow = () =>{
      const win = new BrowserWindow({
        webPreferences: {
          contextIsolation: false, // 是否开启隔离上下文
          nodeIntegration: true, // 渲染进程使用Node API
        },
      });
      if (app.isPackaged) {
        win.loadFile(path.join(__dirname, "../index.html"));
      } else {
        win.loadURL(vueProjectAddress);
      }
    };
    // 打开窗口
    app.whenReady().then(() => {
      createWindow(); // 创建窗口
      app.on("activate", () => {
        if (BrowserWindow.getAllWindows().length === 0) createWindow();
      });
    });
    // 关闭窗口
    app.on("window-all-closed", () => {
      if (process.platform !== "darwin") {
        app.quit();
      }
    });
  8. 在tsconfig.app.json中的include增加配置"electron-main/**/*.ts"

    javascript 复制代码
    "include": [
    "src/**/*.ts",
    "src/**/*.tsx",
    "src/**/*.vue",
    "electron-main/**/*.ts"
    ]
  9. 在vite.config.ts配置

    javascript 复制代码
    import electron from "vite-plugin-electron";
    import electronRenderer from "vite-plugin-electron-renderer";
    export default defineConfig({
      plugins: [
        vue(),
        electron({
          entry: "electron-main/index.ts", // 主进程文件
        }),
        electronRenderer(),
      ],
      build: {
        emptyOutDir: false, // 默认情况下,若 outDir 在 root 目录下,则 Vite 会在构建时清空该目录
      },
    })
  10. 打开package.json,增加以下配置:

    javascript 复制代码
    {
      "name": "my-vue-app",
      "private": true,
      "version": "0.0.0",
      "main": "dist-electron/index.js", // 新增
      "scripts": {
        "dev": "vite",
        "build": "vue-tsc && rimraf dist && vite build && electron-builder",
        "preview": "vite preview"
      },
      // build 新增
      "build": {
        "appId": "com.smallpig.desktop",
        "productName": "smallpig",
        "asar": true,
        "copyright": "Copyright © 2022 smallpig",
        "directories": {
          "output": "release/${version}"
        },
        "files": [
          "dist"
        ],
        "mac": {
          "artifactName": "${productName}_${version}.${ext}",
          "target": [
            "dmg"
          ]
        },
        "win": {
          "target": [
            {
              "target": "nsis",
              "arch": [
                "x64"
              ]
            }
          ],
          "artifactName": "${productName}_${version}.${ext}"
        },
        "nsis": {
          "oneClick": false,
          "perMachine": false,
          "allowToChangeInstallationDirectory": true,
          "deleteAppDataOnUninstall": false
        },
        // 新增
        "publish": [
          {
            "provider": "generic",
            "url": "http://127.0.0.1:8080"
          }
        ],
        "releaseInfo": {
          "releaseNotes": "版本更新的具体内容"
        }
      },
      "dependencies": {
        "electron-devtools-installer": "^3.2.0",
        "vue": "^3.2.45"
      },
      "devDependencies": {
        "@vitejs/plugin-vue": "^4.0.0",
        "electron": "^22.0.2",
        "electron-builder": "^23.6.0",
        "install": "^0.13.0",
        "npm": "^9.3.0",
        "polyfill-exports": "^0.4.0-beta.2",
        "rimraf": "^4.1.0",
        "typescript": "^4.9.3",
        "vite": "^4.0.0",
        "vite-plugin-electron": "^0.11.1",
        "vite-plugin-electron-renderer": "^0.11.4",
        "vue-tsc": "^1.0.11"
      }
    }
  11. 在npm run dev即可

相关推荐
上单带刀不带妹10 分钟前
ES6 中的 Proxy 全面讲解
前端·ecmascript·es6·proxy
11054654011 小时前
37、需求预测与库存优化 (快消品) - /供应链管理组件/fmcg-inventory-optimization
前端·信息可视化·数据分析·js
nunumaymax1 小时前
在图片没有加载完成时设置默认图片
前端
OEC小胖胖2 小时前
【React 设计模式】受控与非受控:解构 React 组件设计的核心模式
前端·react.js·设计模式·前端框架·web
你怎么知道我是队长2 小时前
C语言---编译的最小单位---令牌(Token)
java·c语言·前端
一枚前端小能手3 小时前
🔥 Vue状态管理越写越乱,Pinia拯救了我
前端
cloudcruiser3 小时前
Apache HTTP Server:深入探索Web世界的磐石基石!!!
前端·其他·http·apache
一个专注api接口开发的小白3 小时前
手把手教程:使用 Postman 测试与调试淘宝商品详情 API
前端·数据挖掘·api
芜青4 小时前
JavaScript手录18-ajax:异步请求与项目上线部署
开发语言·javascript·ajax
织_网4 小时前
Electron 核心 API 全解析:从基础到实战场景
前端·javascript·electron