超详细!!!electron-vite-vue开发桌面应用之Electron Forge打包项目(三)

云风网
云风笔记
云风知识库

electronforge可将前端静态页面打包成.exe、.deb和.rpm等,能适配各种平台

一、安装依赖

javascript 复制代码
cd my-app
npm install --save-dev @electron-forge/cli
npm exec --package=@electron-forge/cli -c "electron-forge import"

安装后package.json自动生成新的命令

javascript 复制代码
"scripts": {
   "dev": "vite",
   "build": "vue-tsc && vite build && electron-builder",
   "preview": "vite preview",
   "start": "electron-forge start",
   "package": "electron-forge package",
   "make": "electron-forge make"
}

直接运行npm run start,报错如下

这个报错信息表明你正在使用的 forge.config.js 文件被当作一个ES模块文件处理,因为它是一个.js扩展名的文件,并且在文件内部使用了ES模块的语法(例如 import, export 等)

解决这个问题的方法取决于你的具体需求和项目设置。以下是几种可能的解决方案:

如果你想要 forge.config.js 被当作CommonJS模块处理,你可以将文件扩展名改为 .cjs,Node.js 会默认将

.cjs 文件作为CommonJS模块处理。

如果你需要继续使用 .js 扩展名,并希望文件被当作ES模块处理,确保你的 package.json 文件中包含 "type":

"module",这样Node.js就会将你的项目中的 .js 文件作为ES模块处理。

如果你的项目同时包含CommonJS和ES模块,确保区分它们的文件。CommonJS模块通常是 .cjs 扩展名的,而ES模块通常是

.mjs 扩展名的。

如果你不希望更改文件扩展名,你也可以在 package.json 中设置 "type":

"commonjs",这样整个项目都会默认为CommonJS模块。

这里直接将forge.config.js改为forge.config.cjs,再次运行npm run start,打开出现白屏

javascript 复制代码
(node:78116) electron: Failed to load URL: file:///D:/webPro/yunfeng/electron-vite-project/dist/index.html with error: ERR_FILE_NOT_FOUND
(Use `electron --trace-warnings ...` to show where the warning was created)

这里是由于项目前端部分没有打包,打包文件未读取到,这里改造一下命令

javascript 复制代码
"scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview",
    "start": "vite build&&electron-forge start",
    "package": "vite build&&electron-forge package",
    "make": "vite build&&electron-forge make"
  }

再次运行npm run start 正常显示如下

执行npm run package和npm run make进行项目打包

这里的原因是package.json没有配置author和description

javascript 复制代码
"author": "nie-ch",
"description": "云风笔记桌面端",

再次执行npm run make,生成out/make文件夹,里面存在安装包exe文件

相关推荐
Mintopia3 分钟前
⚙️ Next.js 多环境部署全攻略
前端·javascript·全栈
摸鱼的春哥16 分钟前
组合为啥比继承更高级?以构建buff系统为例
前端·javascript·后端
江城开朗的豌豆16 分钟前
让TS函数"说到做到":返回值类型约束的实战心得
前端·javascript
晓得迷路了24 分钟前
栗子前端技术周刊第 104 期 - Rspack 1.6、Turborepo 2.6、Chrome 142...
前端·javascript·chrome
江城开朗的豌豆27 分钟前
TS泛型:让类型也学会“套娃”,但这次很优雅
前端·javascript
羊羊小栈32 分钟前
基于YOLO+多模态大模型+人脸识别+视频检索的智慧公安综合研判平台(vue+flask+AI算法)
vue.js·人工智能·yolo·flask·毕业设计·音视频·大作业
西洼工作室40 分钟前
vue2+vuex登录功能
前端·javascript·vue.js
艾小码1 小时前
从写原生JS到玩转框架:我走过的那些弯路和顿悟时刻
前端·javascript
Liudef068 小时前
DeepseekV3.2 实现构建简易版Wiki系统:从零开始的HTML实现
前端·javascript·人工智能·html
景早9 小时前
vue 记事本案例详解
前端·javascript·vue.js