使用electron打包vuecli创建的项目

下面是我打包的时候才过的所有的坑💣:

  1. 首先创建一个vue2的空项目,如果全局安装的vue-cli版本太低,低于3就无法使用vue create命令,必须使用uninstall将之前的卸载掉,在重现安装,之后的就是最近的版本。
  2. 首先一定要先去执行一遍vue add electron-builder安装依赖,过程中不能有报错,我的node版本为16.18.0,成功之后就会发现多了一个background.js文件,还有脚本中多了几个打包electron的命令。
  3. 在安装这个electron-builder包的时候,必须将镜像进行设置: npm config set electron_mirror https://npmmirror.com/mirrors/electron/
  4. 设置好镜像之后使用npm install electron electron-builder -g全局安装electron-builder
  5. 对于图标的设置一定要有严格的设置,可以去参考https://www.butterpig.top/icopro网站上进行生成,图标大小一定要选择256×256的,icon类型是用于windows系统桌面的
  6. 打包过程中一定要退出电脑管家等杀毒软件,不然就会提示Fatal error: Unable to commit changes
  7. 打包的路径一定不要包含任何有关中文的文字或符号
  8. 还有一定要详细阅读下面的两篇文章如下:
    https://www.jianshu.com/p/2addf336ab91
    https://www.jianshu.com/p/1dbb96bc8f37
  9. 在参考完第八条之后相信已经配置好了环境,环境配置很难,不要轻易重装电脑,更不要删除本机C:\Users\Administrator\AppData\Local\electron-builder\Cache下面的的任何文件(都是手动加入的,不然无法打包)
  10. 把下面的代码拷贝至vue.config.js文件中

如果有谁还是无法打包可以联系我,我可以远程帮忙,不过一定要记得要先一键三连哦😆😆😆!!!

javascript 复制代码
const { defineConfig } = require('@vue/cli-service')
const path = require("path");
module.exports = defineConfig({
  transpileDependencies: true,
  pluginOptions: {
    electronBuilder: {
      builderOptions: {
        appId: "inspect.cnsbdz.com/",
        productName: "xxxx软件", //项目名,也是生成的安装文件名,即aDemo.exe
        copyright: "Copyright © 2018", //版权信息
        directories: {
          output: "./exeSetUpDist", //输出文件路径,之前编译的默认是dist_electron
        },
        nsis: {
          oneClick: false, // 是否一键安装
          allowElevation: true, // 允许请求提升。 如果为false,则用户必须使用提升的权限重新启动安装程序。
          allowToChangeInstallationDirectory: true, // 允许修改安装目录
          installerIcon: "./public/favicon.ico", // 安装图标
          uninstallerIcon: "./public/favicon.ico", //卸载图标
          installerHeaderIcon: "./public/favicon.ico", // 安装时头部图标
          createDesktopShortcut: true, // 创建桌面图标
          createStartMenuShortcut: true, // 创建开始菜单图标
          shortcutName: "xxxx软件", // 图标名称
        },
        win: {
          icon: "./public/favicon.ico",
          target: [
            {
              target: "nsis", //使用nsis打成安装包,"portable"打包成免安装版
              arch: [
                "x64", //64位
                "ia32", //32位
              ],
            },
          ],
        },
        mac: {
          icon: path.join(__dirname, "./public/favicon.ico"),
        },
        linux: {
          icon: path.join(__dirname, "./public/favicon.ico"),
        },
      },
      publish: [
        {
          provider: "generic", // 服务器提供商,也可以是GitHub等等
          url: "http://xxxxx/", // 服务器地址
        },
      ],
    },
  },
})

然后就可以开始打包了。

最后打完包成功了的话时这样子的

相关推荐
Never_Satisfied10 小时前
在JavaScript / HTML中,Chrome报错Refused to execute inline script
javascript·chrome·html
杨超越luckly10 小时前
HTML应用指南:利用GET请求获取全国中国建设银行网点位置信息
前端·arcgis·html·数据可视化·门店数据
王翼鹏10 小时前
html 全角空格和半角空格
前端·html
敲代码的嘎仔10 小时前
JavaWeb零基础学习Day2——JS & Vue
java·开发语言·前端·javascript·数据结构·学习·算法
CsharpDev-奶豆哥10 小时前
jq获取html字符串中的图片逐个修改并覆盖原html的解决方案
前端·html
Keepreal49611 小时前
pdf文件预览实现
javascript·react.js
IT_陈寒11 小时前
Python性能优化:用这5个鲜为人知的内置函数让你的代码提速50%
前端·人工智能·后端
简小瑞11 小时前
VSCode源码解密:一行代码解决内存泄漏难题
前端·设计模式·visual studio code
邢行行11 小时前
Node.js 核心模块与模块化笔记
前端
Asort11 小时前
JavaScript设计模式(九)——装饰器模式 (Decorator)
前端·javascript·设计模式