解决用electron打包Vue工程(Vite)报错electron : Failed to load URL : xxx... with error : ERR _CONNECTION_REFUSED

解决用electron打包Vue工程(Vite)报错electron : Failed to load URL : xxx... with error : ERR _CONNECTION_REFUSED

Background: 生产环境通过 Electron 直接加载本地文件系统中的静态资源

注:node后的状态码不重要

明明前端工程可以运行,后端连接也没问题,为什么打包完成后总是连不上网址?

网上常规的排错思路:

• 目标服务未运行

• 端口号配置错误

• 防火墙/安全组拦截

• 跨域策略限制

于是你耗费精力一步步来,到头发现还是没有页面,连接错误
可是你忽略了一个必要的前提:
生产环境引用的是经过 Vite 构建、压缩、哈希命名后的文件
构建后的静态资源(如.html)包含指向编译后 JavaScript 文件的引用
你想起来在打包过程中或多或少的修改或新增了一些文件,使之看似符合应有的结构
但即便自己写的代码和网上build后的长相完全一致,打包后也无法被正确引用,因为不是编译过的代码

那如何预先编译一遍所有必要的组件呢?答案很简单,使用npm命令编译一遍:

Terminal: npm run build # 实际执行的是package.json里的scripts.build

复制代码
"name": "DXY 1st",
    "version": "5.3.0",
    "private": true,
    "description": "DXY 666",
    "author": "duandashuaige",
 
 
"scripts": {
 
  "build": "vite build"  //在你package.json中增加scripts参数
 
}

3.打包后会得到根目录下的dist文件夹,dist文件夹里的内容才是打包后机器可以直接引用的文件,里面有:

Assets文件夹,用来存放静态资源(js/CSS/img)
index.html,关键的入口文件,记得把路径改成引用dist里的资源

......

注意事项:build过程中对源文件已有的报错比较严格,如果没有修好某些小报错,build会失败:

修好小bug之后就可以美美build咯:

相关推荐
threelab9 分钟前
Three.js 加载 3D Tiles 瓦片数据 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
No8g攻城狮1 小时前
【AI工具】wsl2 + ubuntu22.04安装部署sub2api详细教程
人工智能·ai·go·vue
_洋1 小时前
Three.js加载 .obj文件 和 .gltf文件
开发语言·javascript·ecmascript
梦想CAD控件1 小时前
网页端对DWG图纸进行预览与批注(CAD轻量化)
java·前端·javascript
JustNow_Man2 小时前
【opencode】安装使用daytona沙箱插件
android·java·javascript
wait2 小时前
Vibe Coding 开发技巧
前端·javascript·人工智能
ZengLiangYi2 小时前
Vercel AI SDK 入门:一行代码切换 LLM Provider
前端·javascript·aigc
三乐2282 小时前
原型链是什么?五分钟教会你
javascript
ZengLiangYi2 小时前
Electron 入门:Web 应用打包成桌面软件
前端·electron
lqj_本人2 小时前
鸿蒙electron跨端框架PC想法卡片实战:把零散灵感做成能继续展开的卡片流
华为·electron·harmonyos