原文地址:https://blog.csdn.net/a1170201028/article/details/59108126

一、安装electron-packager

PS:安装之前,先复制一份package.json文件到./app目录下,然后改下./app目录下package.json里 “main”: “app/main.js”的路径(去掉app/),不这样子的话,下面打包的时候会报错,有的版本识别不了应用路径。

1、使用命令npm install --save-dev electron-packager
将electron-package包安装到在项目下面,

安装完成之后,项目根目录下面的package.json文件里,会多出一条electron-package的版本号配置信息

二、正式打包
有两种方法:
1、直接使用命令打包,electron-packager的打包基本命令是:

electron-packager <location of project> <name platform> <architecture> <electron version> <optional options>
  • 1

命令说明:
* location of project:项目所在路径
* name of project:打包的项目名字
* platform:确定了你要构建哪个平台的应用(Windows、Mac 还是 Linux)
* architecture:决定了使用 x86 还是 x64 还是两个架构都用
* electron version:electron 的版本
* optional options:可选选项

命令比较长,每次要是都用这个命令来打包会很烦,可以使用第二种方法;

2、首先在项目根目录下面的 package.json 里添加代码,
"packager": "electron-packager ./app HelloWorld --all --out ./OutApp --version 1.4.0 --overwrite --icon=./app/img/icon/icon.ico"

PS:这里要注意,字段里的 项目名字,version,icon路径要改成自己的;
具体添加位置如图,

然后,在使用命令npm run-script packager

最后,打包完成之后如图

运行对应包下的.exe文件,就可以看到我们的应用了。

转载自http://blog.csdn.net/arvin0/article/details/52690023

参数设置可参考下面,也是转载自某网友

[html] view plain copy
  1. {
  2. "name":"hosts",
  3. "version":"2.0.1",
  4. "description":"",108);color:inherit;line-height:18px;list-style-position:outside;">"main":"main.js",248);line-height:18px;list-style-position:outside;">"scripts":{
  5. "start":"concurrently\"NODE_ENV=develectron.\"\"webpack-dev-server--inline--hot--port8080\"",
  6. "packageDarwin":"electron-packager.'Hosts'--platform=darwin--arch=x64--icon=hosts.icns--out=./dist--asar--app-version=2.0.1--ignore=\"(dist|src|docs|.gitignore|LICENSE|README.md|webpack.config*|node_modules)\"",
  7. "packageWin":"electron-packager.'Hosts'--platform=win32--arch=x64--icon=hosts.ico--out=./dist--asar--app-version=2.0.1--ignore=\"(dist|src|docs|.gitignore|LICENSE|README.md|webpack.config.js|node_modules)\"",248);line-height:18px;list-style-position:outside;">"packageLinux":"electron-packager.'Hosts'--platform=linux--arch=x64--out=./dist--asar--app-version=2.0.1--ignore=\"(dist|src|docs|.gitignore|LICENSE|README.md|webpack.config.js|node_modules)\"",108);color:inherit;line-height:18px;list-style-position:outside;">"prepackage":"rm-rfbuild&&webpack--configwebpack.config.prod.js&&rm-rfdist",248);line-height:18px;list-style-position:outside;">"package":"npmrunpackageDarwin&&npmrunpackageWin&&npmrunpackageLinux"
  8. },248);line-height:18px;list-style-position:outside;">"author":"Howard.Zuo",108);color:inherit;line-height:18px;list-style-position:outside;">"license":"MIT",248);line-height:18px;list-style-position:outside;">"devDependencies":{
  9. "autoprefixer":"^6.7.6",248);line-height:18px;list-style-position:outside;">"babel-core":"^6.23.1",108);color:inherit;line-height:18px;list-style-position:outside;">"babel-loader":"^6.3.2",248);line-height:18px;list-style-position:outside;">"babel-plugin-component":"^0.9.0",108);color:inherit;line-height:18px;list-style-position:outside;">"babel-plugin-transform-object-rest-spread":"^6.23.0",248);line-height:18px;list-style-position:outside;">"babel-plugin-transform-runtime":"^6.23.0",108);color:inherit;line-height:18px;list-style-position:outside;">"babel-preset-es2015":"^6.22.0",248);line-height:18px;list-style-position:outside;">"concurrently":"^3.4.0",108);color:inherit;line-height:18px;list-style-position:outside;">"css-loader":"^0.26.2",248);line-height:18px;list-style-position:outside;">"electron-packager":"^8.5.2",108);color:inherit;line-height:18px;list-style-position:outside;">"electron-prebuilt":"^1.4.13",248);line-height:18px;list-style-position:outside;">"file-loader":"^0.10.1",108);color:inherit;line-height:18px;list-style-position:outside;">"html-webpack-plugin":"^2.28.0",248);line-height:18px;list-style-position:outside;">"postcss-loader":"^1.3.3",108);color:inherit;line-height:18px;list-style-position:outside;">"postcss-nested":"^1.0.0",248);line-height:18px;list-style-position:outside;">"postcss-simple-vars":"^3.0.0",108);color:inherit;line-height:18px;list-style-position:outside;">"style-loader":"^0.13.2",248);line-height:18px;list-style-position:outside;">"vue-hot-reload-api":"^2.0.11",108);color:inherit;line-height:18px;list-style-position:outside;">"vue-html-loader":"^1.2.4",248);line-height:18px;list-style-position:outside;">"vue-loader":"^11.1.3",108);color:inherit;line-height:18px;list-style-position:outside;">"vue-style-loader":"^2.0.3",248);line-height:18px;list-style-position:outside;">"vue-template-compiler":"^2.2.1",108);color:inherit;line-height:18px;list-style-position:outside;">"webpack":"^2.2.1",248);line-height:18px;list-style-position:outside;">"webpack-dev-server":"^2.4.1"
  10. "dependencies":{
  11. "element-ui":"^1.2.3",248);line-height:18px;list-style-position:outside;">"hostile":"^1.3.0",108);color:inherit;line-height:18px;list-style-position:outside;">"sudo-prompt":"^6.2.1",248);line-height:18px;list-style-position:outside;">"vue":"^2.2.1"
  12. }
  13. }

在windows平台下采用electron-packager打包electron程序为.exe的更多相关文章

  1. 用canvas做一个DVD待机动画的实现代码

    这篇文章主要介绍了用canvas做一个DVD待机动画的实现代码的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  2. HTML5自定义视频播放器源码

    这篇文章主要介绍了HTML5自定义视频播放器源码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  3. Html5 滚动穿透的方法

    这篇文章主要介绍了Html5 滚动穿透的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  4. HTML5自定义mp3播放器源码

    这篇文章主要介绍了HTML5自定义mp3播放器源码,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  5. 详解HTML5中CSS外观属性

    这篇文章主要介绍了HTML5中CSS外观属性的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,,需要的朋友可以参考下

  6. CSS中实现动画效果-附案例

    这篇文章主要介绍了 CSS中实现动画效果并附上案例代码及实现效果,就是CSS动画样式处理,动画声明需要使用@keyframes name,后面的name是人为定义的动画名称,下面我们来看看文章的具体实现内容吧,需要的小伙伴可以参考一下

  7. html5默认气泡修改的代码详解

    这篇文章主要介绍了html5默认气泡修改的代码详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  8. Html5移动端适配IphoneX等机型的方法

    这篇文章主要介绍了Html5移动端适配IphoneX等机型的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  9. 小程序瀑布流解决左右两边高度差距过大的问题

    这篇文章主要介绍了小程序瀑布流解决左右两边高度差距过大的问题的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  10. HTML5自定义元素播放焦点图动画的实现

    这篇文章主要介绍了HTML5自定义元素播放焦点图动画的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

随机推荐

  1. static – 在页面之间共享数据的最佳实践

    我想知道在UWP的页面之间发送像’selectedItem’等变量的最佳做法是什么?创建一个每个页面都知道的静态全局变量类是一个好主意吗?

  2. .net – 为Windows窗体控件提供百分比宽度/高度

    WindowsForm开发的新手,但在Web开发方面经验丰富.有没有办法为Windows窗体控件指定百分比宽度/高度,以便在用户调整窗口大小时扩展/缩小?当窗口调整大小时,可以编写代码来改变控件的宽度/高度,但我希望有更好的方法,比如在HTML/CSS中.在那儿?

  3. 使用Windows Azure查询表存储数据

    我需要使用特定帐户吗?>将应用程序部署到Azure服务后,如何查询数据?GoogleAppEngine有一个数据查看器/查询工具,Azure有类似的东西吗?>您可以看到的sqlExpressintance仅在开发结构中,并且一旦您表示没有等效,所以请小心使用它.>您可以尝试使用Linqpad查询表格.看看JamieThomson的thispost.

  4. windows – SetupDiGetClassDevs是否与文档中的设备实例ID一起使用?

    有没有更好的方法可以使用DBT_DEVICEARRIVAL事件中的数据获取设备的更多信息?您似乎必须指定DIGCF_ALLCLASSES标志以查找与给定设备实例ID匹配的所有类,或者指定ClassGuid并使用DIGCF_DEFAULT标志.这对我有用:带输出:

  5. Windows Live ID是OpenID提供商吗?

    不,WindowsLiveID不是OpenID提供商.他们使用专有协议.自从他们的“测试版”期结束以来,他们从未宣布计划继续它.

  6. 如果我在代码中进行了更改,是否需要重新安装Windows服务?

    我写了一个Windows服务并安装它.现在我对代码进行了一些更改并重新构建了解决方案.我还应该重新安装服务吗?不,只需停止它,替换文件,然后重新启动它.

  7. 带有双引号的字符串回显使用Windows批处理输出文件

    我正在尝试使用Windows批处理文件重写配置文件.我循环遍历文件的行并查找我想要用指定的新行替换的行.我有一个’函数’将行写入文件问题是%Text%是一个嵌入双引号的字符串.然后失败了.可能还有其他角色也会导致失败.如何才能使用配置文件中的所有文本?尝试将所有“在文本中替换为^”.^是转义字符,因此“将被视为常规字符你可以尝试以下方法:其他可能导致错误的字符是:

  8. .net – 将控制台应用程序转换为服务?

    我正在寻找不同的优势/劣势,将我们长期使用的控制台应用程序转换为Windows服务.我们为ActiveMQ使用了一个叫做java服务包装器的东西,我相信人们告诉我你可以用它包装任何东西.这并不是说你应该用它包装任何东西;我们遇到了这个问题.控制台应用程序是一个.NET控制台应用程序,默认情况下会将大量信息记录到控制台,尽管这是可配置的.任何推荐?我们应该在VisualStudio中将其重建为服务吗?我使用“-install”/“-uninstall”开关执行此操作.例如,seehere.

  9. windows – 捕获外部程序的STDOUT和STDERR *同时*它正在执行(Ruby)

    哦,我在Windows上:-(实际上,它比我想象的要简单,这看起来很完美:…是的,它适用于Windows!

  10. windows – 当我试图批量打印变量时,为什么我得到“Echo is on”

    我想要执行一个简单的批处理文件脚本:当我在XP中运行时,它给了我预期的输出,但是当我在Vista或Windows7中运行它时,我在尝试打印值时得到“EchoisOn”.以下是程序的输出:摆脱集合表达式中的空格.等号(=)的两侧可以并且应该没有空格BTW:我通常在@echo关闭的情况下启动所有批处理文件,并以@echo结束它们,所以我可以避免将代码与批处理文件的输出混合.它只是使您的批处理文件输出更好,更清洁.

返回
顶部