本文主要介绍Electron应用如何打包成msi和exe文件。

由于介绍Electron打包成msi和exe的文章很少,官方的文档也一笔带过,在研究的过程中踩了很多坑,所以写下此文,给其他人一个参考。

关于Electron基础知识的文章,官方文档很详细,在此不再赘述,还没入门的童鞋可以看看方的入门文档:

https://github.com/electron/e...

照着本文操作前,请确保电脑上已经安装了NodeJs,Electron模块,然后有一个写好的Electron应用。

1. 打包成运行包

没打包之前,想要用Electron运行你的应用有两种方式

在应用目录打开命令行,输入electron .

在命令行输入electron,启动一个Electron窗口,并把mian.js拖入窗口中。

这种方式不太优雅,我想直接双击就能运行呢?那就要用到常规打包(以下步骤都是在应用根目录,即上图的Electron_Zhihu下):

1.1 安装依赖

常规打包需要用到electron-packager模块,所以先在命令行中输入npm install --save-dev electron-packager安装。

1.2 package.json里添加一条打包命令,免得每次打包都要输入一长串命令

"scripts": {

"package": "electron-packager ./ zhihu --win --out zhihu --arch=x64 --version 1.3.4 --overwrite --ignore=node_modules"

}

参数说明

electron-packager

location of project:应用目录;

name of project:应用名称;

platform:要打包的平台;

architecture:x86 or x64架构;

electron version:electron 版本(不是应用版本);

optional options:其它选项;

1.3 执行npm run-script package开始打包,第一次打包会下载相应平台的包,可能会比较久

打包完毕后,会多出来一个目录,比如我的是zhihu,打开之后,会有一个zhihu-win32-x64目录,里面就是打包生成的各种文件:

zhihu.exe是可以直接双击运行的,resources里是源文件。

注意,node_modules不会被打包进去,如果有依赖,记得进入resources/app目录输入npm install安装一下依赖。

2. 打包成安装包

Electron官方推荐使用grunt-electron-installer模块自动生成 Windows 安装向导。

注意:以下操作都在zhihu-win32-x64的父级目录中

2.1 安装grunt-electron-installer

新建package.json文件

package.json的内容可以简单写下:

{

"name": "zhihu",

"version": "1.0.0"

}

打开命令行,输入npm install grunt-electron-installer --save-dev安装grunt-electron-installer模块,接着输入npm install grunt --save-dev安装grunt。

2.2 配置Gruntfile.js

因为要用到grunt执行打包任务,所以,新建一个Gruntfile.js文件,并配置gurnt.config,我的配置如下:

var grunt = require("grunt");

grunt.config.init({

pkg: grunt.file.readJSON('package.json'),

'create-windows-installer': {

x64: {

appDirectory: './zhihu-win32-x64',

authors: 'yohnz.',

exe: 'zhihu.exe',

description:"zhihu",

}

}

})

grunt.loadNpmTasks('grunt-electron-installer');

grunt.registerTask('default', ['create-windows-installer']);

配置说明:

Config Name

Required

Description

appDirectory

Yes

Electron App 的目录

outputDirectory

No

输出exe的目录. 默认生成在installer目录.

loadingGif

No

安装过程中的加载动画图片.

authors

Yes

作者,若未指明,则从应用的package.json文件中读取

owners

No

应用拥有者,若未定义则与作者相同.

exe

No

应用的入口exe名称.

description

No

应用描述

version

No

应用版本号.

title

No

应用的标题.

certificateFile

No

证书文件

certificatePassword

No

加密密钥

signWithParams

No

传递给signtool签名工具的参数,如果软件不签名,可以忽略这个

iconUrl

No

应用图标链接,默认是Atom的图标.

setupIcon

No

Setup.exe 的icon

noMsi

No

是否创建.msi安装文件?

remoteReleases

No

更新链接,如果填写,当链接中有新版本,会自动下载安装。

2.3 grunt打包

在命令行输入npm grunt,就会执行自动构建安装程序。在构建完之后的installer目录(或者你配置的输出目录)中会有如下几个文件

运行setup.exe就开始自动安装了,我们去'控制面板->程序和功能'里检验一下,发现应用已经安装了。

2.4 生成快捷方式

到此处,Electron的安装文件就打包好了,但是装完之后,没有自动生成快捷方式,所以,我们要在main.js里加入生成快捷方式的功能。

添加监听并生成快捷方式

var handleStartupEvent = function () {

if (process.platform !== 'win32') {

return false;

}

var squirrelCommand = process.argv[1];

switch (squirrelCommand) {

case '--squirrel-install':

case '--squirrel-updated':

install();

return true;

case '--squirrel-uninstall':

uninstall();

app.quit();

return true;

case '--squirrel-obsolete':

app.quit();

return true;

}

// 安装

function install() {

var cp = require('child_process');

var updateDotExe = path.resolve(path.dirname(process.execPath), '..', 'update.exe');

var target = path.basename(process.execPath);

var child = cp.spawn(updateDotExe, ["--createShortcut", target], { detached: true });

child.on('close', function(code) {

app.quit();

});

}

// 卸载

function uninstall() {

var cp = require('child_process');

var updateDotExe = path.resolve(path.dirname(process.execPath), '..', 'update.exe');

var target = path.basename(process.execPath);

var child = cp.spawn(updateDotExe, ["--removeShortcut", target], { detached: true });

child.on('close', function(code) {

app.quit();

});

}

};

if (handleStartupEvent()) {

return;

}

运行步骤1.3和2.3重新打包,此时,再次运行setup.exe进行安装,就会自动再桌面和开始菜单生成快捷方式了。但是,你可能会发现快捷方式的名字是Electron而不是你设置的应用名。如果比较处女座,可以继续执行一下步骤:

2.5. 修改打包参数

修改步骤1.2中的打包参数,添加:--version-string.CompanyName=zhihu --version-string.ProductName=zhihu

完整命令如下:

"scripts": {

"package": "electron-packager ./ zhihu --win --out zhihu --arch=x64 --version 1.3.4 --overwrite --ignore=node_modules --version-string.CompanyName=zhihu --version-string.ProductName=zhihu"

},

然后重新运行步骤1.3和2.3进行打包,此时再编译好的安装包就可以运行并生成桌面快捷方式和开始菜单了。

运行截图

php程序打包exe文件下载,手把手教你把前端代码打包成msi和exe文件相关推荐

  1. cmd代码表白_手把手教你把Python代码转成exe

    [文末有福利] 很多刚入门的盆友都有疑惑怎么把Python代码转成可执行的exe?,这里行哥统一解决一下这个问题 1.在cmd里安装pyintsaller包 2.在cmd里输入打包成exe的命令 3. ...

  2. 手把手教你如何Vue项目打包dist文件并Tomcat发布【超级详细】

    ???作者:bug菌 博客:CSDN.掘金等 ??公众号:猿圈奇妙屋 ??特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合. ??版权声明:文章里可能部分文字或者图片来源于互联网或者百度 ...

  3. VS2017桌面应用程序打包成.msi或者.exe

    1.安装打包插件:Microsoft Visual Studio 2017 Installer Projects 打开vs2017 ,选择 工具 --> 扩展和更新 --> 联机,搜索Mi ...

  4. [ROC-RK3568-PC] 手把手教你编译Linux_SDK并打包Buildroot系统固件

    ✏️ROC-RK3568-PC入门篇连载进程: ✅ [ROC-RK3568-PC] 手把手教你把出厂的Android系统烧写为Ubuntu系统 ✅ [ROC-RK3568-PC] 手把手教你制作Ubu ...

  5. vs2017c语言程序打包,VS2017桌面应用程序打包成.msi或者.exe

    1.安装打包插件:Microsoft Visual Studio 2017 Installer Projects 打开vs2017 ,选择 工具 --> 扩展和更新 --> 联机,搜索Mi ...

  6. vs2017python如何打包exe_VS2017项目程序打包成.msi或者.exe

    VS2017项目程序打包成.msi或者.exe 1.安装打包插件:Microsoft Visual Studio 2017 Installer Projects 打开vs2017 ,选择 工具 --& ...

  7. 【C#】VS2017桌面应用程序打包成.msi或者.exe

    1.安装打包插件:Microsoft Visual Studio 2017 Installer Projects 打开vs2017 ,选择 工具 --> 扩展和更新 --> 联机,搜索Mi ...

  8. 手把手教你 Creator 2.x 打包 Android APK(Mac篇)

    上一篇我们分享了<手把手教你 Creator 2.x 打包 Android APK(Windows篇)>,今天继续分享 MAC 下的 Android 环境配置. 官方文档: 安装配置原生开 ...

  9. python跑得慢_代码跑得慢甩锅Python?手把手教你如何给代码提速30%

    原标题:代码跑得慢甩锅Python?手把手教你如何给代码提速30% 来源丨Medium 编译丨王转转 大数据文摘出品 https://mp.weixin.qq.com/s/bY3REj6qVw0M1N ...

最新文章

  1. Paper4:Voxel-Based Extraction and Classification of 3-D Pole-Like Object From Mobile LIDAR Point Clo
  2. 关于idea plugin测试那些事(纯手工翻译,只为打发时间,如果有错误,欢迎提建议,如果有意见,我相信别家一定更适合你)
  3. bzoj4592[SHOI2015]脑洞治疗仪
  4. C# 7.0 新特性:本地方法
  5. Linux学习笔记2-文件读写操作
  6. Win10任务计划+PowerShell实现Git自动推送
  7. systemverilog 关联数组
  8. php rewinddir(),PHP rewinddir() 函数 ——jQuery中文网
  9. 写这么骚的代码,真不怕被同事揍么?
  10. 机房管理降本增效:Hightopo如何将可视化监控做到行业高阶?
  11. 【代码实现】tag-based-multi-span-extraction
  12. XP系统无法访问\\192.168.1.104无法访问。你可能没有权限使用网络资源。与这台服务器的管理员联系以查明你是否有访问权限
  13. 别着急抢iPhone 13了!拍照有马赛克,苹果确认部分iPhone13存在bug
  14. c语言printf输出整数数字,C语言 念数字 输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu字...
  15. 分布式系统数据层设计模式
  16. Ogre procedural 几何图元库
  17. 黑盒测试——NextDate函数测试(判定表驱动法)
  18. Unity_UIWidgets新手入门
  19. 一次真实的入侵-------记对一足球推荐站点的渗透
  20. 经营棋牌室的难点和痛点

热门文章

  1. 5.15 英语单词小记
  2. NOI的1.9.8白细胞计数
  3. FileStore omap的实现
  4. python小乌龟编程_新手学python ——《小乌龟吃小鱼》小游戏 第二版
  5. 王道操作系统网课笔记合集
  6. android换手机照片怎么转移,换手机了怎么把照片转移到新手机
  7. vue3 ref函数用法
  8. 实时时钟(Real_Time Clock)电路--中微爱芯
  9. 很有哲理的句子,每天都值得看一遍
  10. 条形码、二维码、RFID优缺点,卫星定位,传感器分类及应用场景