如果应用程序匹配不上系统很可能会造成打不开的情况,所以下面将会介绍一下如何使用Electron-builder打包成系统的安装包。
打包成不同位数的安装包的方式是通过定义package.json文件中的scripts的参数值去实现。(通过build参数对打包相关进行配置)
命令行参数(CLI)
我们可以直接执行一下相关命令,或者在package.json文件中简写对应参数。
如:
{
"name": "electron-builder",
"scripts": {
"build": "electron-builder --win --ia32",
},
}
以下是打包成Windows 32位系统的参数:
electron-builder --win --ia32
以下是Windows 64位系统的参数:
electron-builder --win --ia64
以下是linux系统的参数:
electron-builder --linux
以下是mac系统的参数:
electron-builder --mac
通过build参数配置打包配置
"build": {
"productName":"xxxx",//项目名 这也是生成的exe文件的前缀名
"appId": "com.leon.xxxxx",//包名
"copyright":"xxxx",//版权 信息
"directories": { // 输出文件夹
"output": "build"
},
"nsis": {
"oneClick": false, // 是否一键安装
"allowElevation": true, // 允许请求提升。 如果为false,则用户必须使用提升的权限重新启动安装程序。
"allowToChangeInstallationDirectory": true, // 允许修改安装目录
"installerIcon": "./install.ico",// 安装图标
"uninstallerIcon": "./uninstall.ico",//卸载图标
"installerHeaderIcon": "./installheader.ico", // 安装时头部图标
"createDesktopShortcut": true, // 创建桌面图标
"createStartMenuShortcut": true,// 创建开始菜单图标
"shortcutName": "xxxx", // 图标名称
"include": "build/script/installer.nsh", // 包含的自定义nsis脚本
},
"publish": [
{
"provider": "generic", // 服务器提供商 也可以是GitHub等等
"url": "http://xxxxx/" // 服务器地址
}
],
"files": [ // 携带文件路径
"dist/electron/**/*"
],
"dmg": { //mac系统dmg包配置
"contents": [
{
"x": 410,
"y": 150,
"type": "link",
"path": "/Applications"
},
{
"x": 130,
"y": 150,
"type": "file"
}
]
},
"mac": { //mac系统包配置
"icon": "build/icons/icon.icns"
},
"win": { //window系统包配置
"icon": "build/icons/aims.ico",
"target": [
{
"target": "nsis",
"arch": [
"ia32"
]
}
]
},
"linux": { //linux系统包配置
"icon": "build/icons"
}
}
Electron支持的WIN系统版本
Electron 22.0.0是最后一个支持Windows 7的版本。在这个版本中,Electron包括了新的实用进程API、对Windows 7/8/8.1支持的更新,以及对Chromium 108、V8 10.8和Node.js 16.17.1的升级。
从Electron 23.0.0开始,Electron取消了对Windows 7/8.1的支持,这标志着Electron将不再支持这些旧版本的操作系统。此外,这一变化与Chromium的弃用政策相符,也呼应了Microsoft对Windows 7 ESU(扩展安全更新)和Windows 8.1扩展支持结束的政策。