美文网首页
electron入门

electron入门

作者: hzl的学习小记 | 来源:发表于2019-08-14 11:42 被阅读0次

Electron是由Github开发,用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库。 Electron通过将Chromium和Node.js合并到同一个运行时环境中,并将其打包为Mac,Windows和Linux系统下的应用来实现这一目的。

使用eletron前需要储备哪些知识

1、首先需要熟练掌握前端的基础知识html,css,js

2、有一定的node基础,知道npm怎么用

下面我们从electron的安装开始,了解下electron。

1. electron 安装

安装前先安装 node.js 与 yarn / npm

mkdir electron-demo
cd electron-demo
yarn init -y
yarn add --dev electron 
npx electron -v

2. 创建项目目录

main.js
index.html

在 package.json中添加script 
"start": "electron ."
修改main
"main": "main.js" 

3. 编写electron的demo

<!-- index.html -->
<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>Hello World!</title>
  </head>
  <body>
    <h1>Hello World!</h1>
    We are using node <script>document.write(process.versions.node)</script>,
    Chrome <script>document.write(process.versions.chrome)</script>,
    and Electron <script>document.write(process.versions.electron)</script>.

    <br>
    <button id="hiBtn">hi</button>
    <script>
        document.getElementById('hiBtn')
        .onclick = function(){
            alert('hi')
        }
    </script>
  </body>
</html>
// main.js
const { app, BrowserWindow } = require('electron')

function createWindow () {   
  // 创建浏览器窗口
  let win = new BrowserWindow({
    width: 800,
    height: 600,
    webPreferences: {
      nodeIntegration: true
    }
  })

  // 加载index.html文件
  win.loadFile('index.html')
}

app.on('ready', createWindow)

使用 yarn start 运行

image.png image.png

4. 使用electron-bulder打包项目

首先来看看什么是electron-builder:
简单的说,electron-builder就是将已有的electron应用打包成msi格式和exe可执行文件的工具。打包是一个成熟的应用程序一个重要的环节,希望这篇文章可以给大家一些参考,最后会讲到打包时遇到的一些坑,与大家分享。

// 安装electron-bulder依赖
yarn add electron-builder --dev

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

"devDependencies": {
  "electron-builder": "^21.2.0"
}

package.json中做如下配置

 "build": {
    "appId": "com.hzlapp.app",
    "mac": {
      "category": "your.app.category.type"
    }
  },
  "scripts": {
    "pack": "electron-builder --dir",
    "dist": "electron-builder",
    "postinstall": "electron-builder install-app-deps",
    "start": "electron ."
  }

在命令行中输入````yarn dist```

打包后在dist目录生成如下文件:

解压zip包或执行setup安装文件,应用启动后且没有报错,则说明本次打包成功。

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

electron-builder打包流程遇到的坑

在第一次输入yarn dist

electron-builder有一些依赖包如 【winCodeSign】、【nsis】;在没墙的情况下,直接执行命令就会自动处理相关依赖,但天朝基本不行,所以会出现包安装超时等的一些情况,就算开了vpn也下载很慢,解决方法如下:

1.第一步:打开链接: https://github.com/electron-userland/electron-builder-binaries/releases 下载 winCodeSign 和 Source code

2.第二步:选择 winCodeSign-2.5.0.7zSource code(zip)下载并解压,source code里面已经包含nsis

3.第三步:在%LOCALAPPDATA%(C:\Users\Administrator\AppData\Local)目录下新建electron-builder\cache\

4.第四步:将 winCodeSign-2.5.0.7z 中的文件 与 Source code(zip)中的nsis解压到第三步的目录下,根据错误提示的版本在对于的包下面新建对于的版本,并把文件移动到目录下,便可正常打包,如图:

相关文章

  • electron 编写 hello world

    任务: 使用electron 编写 hello world 入门程序 electron是什么? Electron ...

  • Electron

    Electron 快速入门

  • electron

    electron vue桌面应用入门实例 从零开始搭建,基于electron vue cli3 的桌面应用。git...

  • Electron学习笔记(一)

    Electron学习笔记(Mac) 参考资料:官方指南中文版快速入门 官网例子Electron-quick-sta...

  • Electron学习笔记(一)

    Electron学习笔记(Mac) 参考资料:官方指南中文版快速入门 官网例子Electron-quick-sta...

  • Electron入门

    简介 https://electronjs.org/一个平台,可以开发跨平台桌面应用核心思想:希望通过一套代码在不...

  • electron入门

    Electron是由Github开发,用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库...

  • electron入门

    标签: electron 简介 electron使用html,css和JavaScript来构建块跨平台桌面应用程...

  • Electron入门

    一.什么是electron? 官方文档:https://www.electronjs.org/docs Elect...

  • Electron入门

    1 helloworld 2 进程介绍 | 调试 渲染进程 主进程main.js所在的进程 ctrl + shif...

网友评论

      本文标题:electron入门

      本文链接:https://www.haomeiwen.com/subject/jpamjctx.html