我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Electron学习应用程序打包实例详解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Electron学习应用程序打包实例详解

引言

人真的是会变得越来越懒的,也正是人的惰性吧,真的是很讽刺。

关于这个应用程序的开发,断更了很久,但是代码部分还算没落下吧,终于在周一、周二终把这个应用程序写完了。

开发完不是终点。而是打包后可以使用才真的算是结束吧。

如何将应用程序打包(Win)

1、关于package.js文件详解

完整实例如下:

json

"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打包

使用如下命令安装:

highlighter-

npm install electron-packager --save-dev

安装好之后会在package.json中的devDependencies生成代码:

highlighter- Bash

"devDependencies": {
    "electron-packager": "^9.1.0"
}

为在package.json中添加如下代码:

highlighter- Bash

"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。

安装依赖:

npm

yarn add electron-builder --save-dev

package.json中做如下配置

highlighter- Bash

"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添加

highlighter- Bash

"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、支持CLIJS API两种使用方式;

整个过程看似很简单,可能也就只有自己知道有多难吧。

整体感受

万事开头难,在开发环境的搭建及应用程序的打包方面花费的时间是最多,目前网上的博主真的好多,但是靠谱的真的很少,大部分都是复制别人的,真的很坑。

整个过程下来,中间个人原因扔下很久,但是个人觉得还是很值得学习的。

值得说是,如果前端不好的同学渗入(比如我),但是学完,真的是会让你自己前端开发水平,会有很大的提升,整个案例使用很多知识点,真的是受益匪浅。

目前自己可以创建一个简单的electron应用,并且可以使用electron在主进程、渲染进程间实现通信,算是入门了吧,确实挺好玩的,以后有时间可以再渗入研究下。

效果

最后我们来看下效果吧......

以上就是Electron学习应用程序打包实例详解的详细内容,更多关于Electron应用程序打包 的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Electron学习应用程序打包实例详解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Electron打包React生成桌面应用方法详解

这篇文章主要介绍了React+Electron快速创建并打包成桌面应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2022-12-21

学习如何使用golang高效打包应用程序:逐步指南

高效使用Golang进行打包:一步步教你如何打包你的应用程序,需要具体代码示例引言:现代应用程序开发越来越注重性能和效率,而Golang作为一门高效、并发和可扩展的编程语言,备受开发者的喜爱。在Golang中,打包是将应用程序与所有依赖项打
学习如何使用golang高效打包应用程序:逐步指南
2023-12-29

Android多线程学习实例详解

本文实例分析了Android多线程。分享给大家供大家参考,具体如下: 在Android下面也有多线程的概念,在C/C++中,子线程可以是一个函数,一般都是一个带有循环的函数,来处理某些数据,优先线程只是一个复 杂的运算过程,所以可能不需要w
2022-06-06

学习使用grunt来打包JavaScript和CSS程序的教程

Java世界里的Maven提供了强大的包依赖管理和构建生命周期管理。在JavaScript的世界里,随着Node.js的流行,JavaScript原生的构建工具已经成为可能。 Grunt.js是基于Node.js的自动化任务运行器。Grun
2022-06-04

编程热搜

目录