vue3(vite)+electron打包踩坑记录(1)

vue3(vite)+electron打包踩坑记录 - 打包vue

第一步 编译vue

使用vite构建vue,package.json如下

javascript 复制代码
{
  "name": "central-manager",
  "private": true,
  "version": "0.0.0",
  "type": "commonjs",
  "main": "main.js",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "build:electron": "electron-builder",
    "preview": "vite preview",
    "start": "nodemon --exec electron . --watch ./ --ext .js,.html,.css,.vue"
  },
  "build": {
    "appId": "com.example.app",
    "productName": "最终产品的名称",
    "win": {
      "target": [
        "nsis",
        "portable"
      ]
    },
    "files": [
      "dist/**/*",
      "src/**/*",
      "data/**/*",
      "preload/**/*",
      "main.js"
    ]
  },
  "dependencies": {
    "node-fetch": "^2.7.0",
    "pinia": "^2.1.7",
    "vue": "^3.3.4",
    "vue-router": "^4.3.0",
    "winston": "^2.4.7",
    "winston-daily-rotate-file": "^5.0.0"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^4.2.3",
    "electron": "^28.1.1",
    "electron-builder": "^24.12.0",
    "nodemon": "^3.0.2",
    "vite": "^4.4.5"
  }
}

执行 npm run build,编译vue项目。

遇到的问题:

Not allowed to load local resource:

我一开始认为,既然编译了vue,那么在electron中就可以使用loadFile来加载index.html

javascript 复制代码
    createWindow() {


        // Create the browser window.
        this.mainWindow = new BrowserWindow({
         ...创建窗口的其他代码
            
        // 在开发模式下加载 Vite 开发服务器
        // 在生产模式下加载编译后的静态文件
        
        const startUrl = process.env.NODE_ENV === 'development'
            ? 'http://localhost:5173' // Vite dev server URL
            : `file://${path.join(__dirname, '../../../dist/index.html')}`;

        // 加载 index.html
        this.mainWindow.loadFile(startUrl)
        // mainWindow.loadFile('./src/index.html')
        // 打开开发工具
        this.mainWindow.webContents.openDevTools()
    }

结果就是:

解决方法:使用 loadUrl()

ERR_FILE_NOT_FOUND错误

然后继续报错:

B站找视频,找到解决方案。

在vite.config.js加base配置:

javascript 复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path';

// https://vitejs.dev/config/
export default defineConfig({
  plugins: [vue()],
  base: path.resolve(__dirname, './dist/')
})

然后控制台重新执行 npm run build

发现还是和上面一样的错误。借鉴别人视频,看到vue编译后,index.html中的资源引用应该为绝对路径。我检查了一下我的index.html,发现个怪异的问题。

路径前面的盘符不知道为什么缺失。我的项目在E盘,所以我直接手动加上 E:。

成功加载:

第二步 打包electron

我使用的是electron-builder,执行nmp run build:electron。顺利打包出exe。

运行exe,没有问题,但是图标没有显示,继续琢磨。后续会更新。

相关推荐
Highcharts.js7 分钟前
缺失数据可视化图表开发实战|Highcharts创建人员出生统计面积图表示例
开发语言·前端·javascript·信息可视化·highcharts·图表开发
LaughingZhu7 小时前
Product Hunt 每日热榜 | 2026-05-21
前端·人工智能·经验分享·chatgpt·html
怕浪猫7 小时前
Electron 开发实战(一):从零入门核心基础与环境搭建
前端·electron·ai编程
辰海Coding7 小时前
MiniSpring框架学习笔记-解决循环依赖的简化IoC容器
笔记·学习
晓梦林7 小时前
cp520靶场学习笔记
android·笔记·学习
小鹏linux8 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
心中有国也有家8 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
前端若水9 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
玄米乌龙茶1239 小时前
LLM成长笔记(三):API 开发基础
笔记
Upsy-Daisy9 小时前
AI Agent 项目学习笔记(八):Tool Calling 工具调用机制总览
人工智能·笔记·学习