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,配置如下:

    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" 
    "include": [
    "src/**/*.ts",
    "src/**/*.tsx",
    "src/**/*.vue",
    "electron-main/**/*.ts"
    ]

  9. 在vite.config.ts配置
    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,增加以下配置:
    {
      "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个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值