如何将应用程序打包(Win)
1、关于package.js
文件详解
完整实例如下:
"build": {
"productName":"xxxx",//项目名 这也是生成的exe文件的前缀名
"appId": "com.leon.xxxxx",//包名
"copyright":"xxxx",//版权 信息
"directories": { // 输出文件夹
"output": "build"
},
"nsis": {
"oneClick": false, // 是否一键安装
"allowElevation": true, // 允许请求提升。 如果为false,则用户必须使用提升的权限重新启动安装程序。
"allowToChangeInstallationDirectory": true, // 允许修改安装目录
"installerIcon": "./build/icons/aaa.ico",// 安装图标
"uninstallerIcon": "./build/icons/bbb.ico",//卸载图标
"installerHeaderIcon": "./build/icons/aaa.ico", // 安装时头部图标
"createDesktopShortcut": true, // 创建桌面图标
"createStartMenuShortcut": true,// 创建开始菜单图标
"shortcutName": "xxxx", // 图标名称
"include": "build/script/installer.nsh", // 包含的自定义nsis脚本
},
"publish": [
{
"provider": "generic", // 服务器提供商 也可以是GitHub等等
"url": "http://xxxxx/" // 服务器地址
}
],
"files": [
"dist/electron/**/*"
],
"dmg": {
"contents": [
{
"x": 410,
"y": 150,
"type": "link",
"path": "/Applications"
},
{
"x": 130,
"y": 150,
"type": "file"
}
]
},
"mac": {
"icon": "build/icons/icon.icns"
},
"win": {
"icon": "build/icons/aims.ico",
"target": [
{
"target": "nsis",
"arch": [
"ia32"
]
}
]
},
"linux": {
"icon": "build/icons"
}
}
2、使用electron-packager打包
使用如下命令安装:
npm install electron-packager --save-dev
安装好之后会在package.json
中的devDependencies
生成代码:
"devDependencies": { "electron-packager": "^9.1.0" }
为在package.json
中添加如下代码:
点击查看代码
"scripts": {
"dist": "electron-builder --win --x64",
"package": "electron-packager ./ --overwrite -all"
}
命令行中执行npm run package
进行打包如下所示:
打包成功后,会在根目录下(此处的目录是可在参数中配置的)下生成.exe,运行该文件,并且没有报错,则说明本次打包成功
特点:
1、支持平台有:Windows (32/64 bit)、OS X (also known as macOS)、Linux (x86/x86_64);
2、进行应用更新时,使用electron
内置的autoUpdate
进行更新
3、支持CLI
和JS API
两种使用方式;
3、使用electron-builder打包
electron-builder
比electron-packager
有更丰富的的功能,支持更多的平台,同时也支持了自动更新。除了这几点之外,由electron-builder
打出的包更为轻量,并且可以打包出不暴露源码的setup
安装程序。考虑到以上几点,我果断选择了electron-builder
。
安装依赖:
yarn add electron-builder --save-dev
在package.json
中做如下配置
点击查看代码
"build": {
"appId": "simpleMusicPlayer",
"mac": {
"category": "public.app-category.productivity"
},
"dmg": {
"background": "build/appdmg.png",
"icon": "build/icon.icns",
"iconSize": 100,
"contents": [
{
"x": 380,
"y": 280,
"type": "link",
"path": "/Applications"
},
{
"x": 110,
"y": 280,
"type": "file"
}
],
"window": {
"width": 500,
"height": 500
}
},
"linux": {
"target": [
"AppImage",
"deb"
]
},
"win": {
"target": ["nsis","zip"],
"icon": "build/icon.ico"
}
}
scripts
添加
"scripts": { "dist": "electron-builder --win --x64" },
使用npm run dist
打包
打包后在dist
目录生成如下文件:
解压zip包或执行setup安装文件,应用启动后且没有报错,则说明本次打包成功。
特点:
1、electron-builder
可以打包成msi
、exe
、dmg
文件,macOS
系统,只能打包dmg
文件,window
系统才能打包exe
,msi
文件;
2、几乎支持了所有平台的所有格式;
3、支持Auto Update
;
4、支持CLI
和JS API
两种使用方式;
目前自己可以创建一个简单的electron
应用,并且可以使用electron
在主进程、渲染进程间实现通信,算是入门了吧,确实挺好玩的,以后有时间可以再渗入研究下。