首页 > 编程语言 >Electron学习(四)之应用程序打包

Electron学习(四)之应用程序打包

时间:2022-09-19 00:44:52浏览次数:83  
标签:-- builder electron 应用程序 Electron build 打包 icon

如何将应用程序打包(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进行打包如下所示:

image

打包成功后,会在根目录下(此处的目录是可在参数中配置的)下生成.exe,运行该文件,并且没有报错,则说明本次打包成功
image
特点:

1、支持平台有:Windows (32/64 bit)、OS X (also known as macOS)、Linux (x86/x86_64);
2、进行应用更新时,使用electron内置的autoUpdate进行更新
3、支持CLIJS API两种使用方式;
3、使用electron-builder打包
electron-builderelectron-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打包
image

打包后在dist目录生成如下文件:
image
解压zip包或执行setup安装文件,应用启动后且没有报错,则说明本次打包成功。

特点:
1、electron-builder 可以打包成msiexedmg文件,macOS系统,只能打包dmg文件,window系统才能打包exemsi文件;
2、几乎支持了所有平台的所有格式;
3、支持Auto Update
4、支持CLIJS API两种使用方式;

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

标签:--,builder,electron,应用程序,Electron,build,打包,icon
From: https://www.cnblogs.com/as3Gui/p/16706391.html

相关文章