用Electron创建跨平台应用(第一弹)

简介: 用Electron创建跨平台应用连载目录:用Electron创建跨平台应用(第一弹)用Electron创建跨平台应用(第二弹)开启多窗口用Electron创建跨平台应用(第三弹)开启系统通知Electron是GitHub开发的一个开源框架,它使用Node.js(作为后端)和Chromium(作为前端)完成桌面GUI应用程序的跨平台开发,目前,Electron已经创建了包括VScode和Atom在内的大量应用。

用Electron创建跨平台应用连载目录:

  • Electron是GitHub开发的一个开源框架,它使用Node.js(作为后端)和Chromium(作为前端)完成桌面GUI应用程序的跨平台开发,目前,Electron已经创建了包括VScode和Atom在内的大量应用。


  • 如果你有htmlcssjs, Nodejs的基础, 掌握Electron将是一件非常容易的事
  • 如果你是一个前端工程师, 掌握了Electron,你无需学习C,Java, 或Python, 就可以创建跨平台的桌面级应用

安装electron

npm install -g electron

用electron-forge创建一个项目

electron-forge是一个脚手架程序(和create-react-app类似), 它可以帮我们快速构建一个electron应用, 应用创建成功后, 我们直接编辑src/index.html即可快速上手electron桌面程序, 下面是创建的具体步骤和几个简单实用的小demo

全局安装electron-forge

npm install -g electron-forge

用electron-forge快速创建项目zhaoolee-electron-app

electron-forge init zhaoolee-electron-app

开启项目


cd zhaoolee-electron-app
npm start

Demo1: 更改index.html内容, 用html css进行布局

  • index.html源码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>工程师的五个级别</title>
</head>

<body>
    <style>
    .title {
        font-weight: bold;
        font-size: 36px;
    }

    ol li {
        list-style: none;
        color: #413F43;
        font-size: 26px;
        line-height: 40px;
        position: relative;
    }

    ol li:hover {
        background-color: #FCF6E5;
    }

    ol li:hover:after {
        font-size: 20px;
        border: 1px solid #AB3319;
        border-radius: 5px;
        content: attr(data);
        position: absolute;
        right: 0;
        opacity: 1;
        transition: all 0.2s ease-out;
    }



    </style>
    <div class="title">工程师的五个级别</div>
    <ol>
        <li data="爱迪生、福特、贝尔、香农、理查德.斯托曼">
            第一级:开创一个产业
        </li>
        <li data="迪恩,丹尼斯.里奇,肯·汤普逊">第二级: 能设计和实现别人不能做出的产品</li>
        <li data="张小龙,阮一峰">第三级: 能独立设计和实现产品并且能在市场上获得成功</li>
        <li data="项目主管">第四级: 能领导和带领其他人一同完成更有影响力的工作</li>
        <li data="两年开发经验的工程师">第五级: 能独立解决问题, 完成工程工作</li>
    </ol>
</body>

</html>

如果出现中文乱码, command+shift+R 刷新缓存即可解决

Demo2: 读取本地文件

浏览器中的js是无法读取本地文件的, 但electron有了node的的加持, 可以随意读取本地的文件, 这里以读取index.html同级目录下的main.js为例

  • index.html 源码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>读取本地文件</title>
</head>

<body>
    <button id="btn">展示index.js内容</button>
    <div id="package-json-area">
    </div>
</body>
<script>
const fs = require("fs");
const path = require("path");
let btn = document.getElementById("btn");
console.log(btn);
btn.addEventListener('click', function(e) {
    fs.readFile(path.join(__dirname, "index.js"), "utf-8", function(err, data) {
        if (err) {
            console.log(err);
        } else {
            console.log(data);
            document.getElementById("package-json-area").innerHTML = data;
        }
    })
})
</script>

</html>

Demo3: 拖拽读取本地文件

  • index.html 源码
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <title>拖拽读取文件</title>
</head>
<style>
body {
    margin: 0;
    padding: 0;
}

#text-area {
    height: 300px;
    background-color: #FCF6E5;
    position: relative;
    font-size: 20px;
    overflow: auto;
    font-weight: bold;
}

#text-area #info {
    border-radius: 20px;
    height: 100px;
    font-size: 40px;
    color: #A84631;
    text-align: center;
    line-height: 100px;
    position: absolute;
    margin: auto;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
}
</style>

<body>
    <div id="text-area">
        <div id="info">将文件拖拽到此处打开</div>
    </div>
</body>
<script>
/*释放目标时触发的事件:
        ondragenter - 当被鼠标拖动的对象进入其容器范围内时触发此事件
        ondragover - 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
        ondragleave - 当被鼠标拖动的对象离开其容器范围内时触发此事件
        ondrop - 在一个拖动过程中,释放鼠标键时触发此事件
    */
const fs = require("fs");
const path = require("path");

let textArea = document.getElementById("text-area")
textArea.ondragenter = textArea.ondragover = textArea.ondragleave = function(e) {
    e.preventDefault();
}

textArea.ondrop = function(e) {
    e.preventDefault();
    let filePath = e.dataTransfer.files[0].path;
    console.log(filePath);
    fs.readFile(filePath, "utf-8", function(err, data){
        textArea.innerHTML = data;
    })

}

</script>

</html>

小结:

  • 有了nodejs, 前端程序员, 获得了开发网站后台的能力!
  • 有了 React-Native, 前端程序员有了开发跨平台app的能力!
  • 有了Electron, 我们可以自由的读取本地的文件, 随意调用npm下的大量工具包, 当然也可以把在线h5小游戏快速移植为桌面游戏, 前端程序员,可以使用已掌握的前端技术, 分一块桌面软件的蛋糕, 真香!
目录
相关文章
|
3月前
|
Rust 前端开发 JavaScript
IM跨平台技术学习(十):快速对比跨平台框架Electron、Flutter、Tauri、React Native等
在本文中,我们将比较五种流行的桌面应用程序开发框架:Electron、Flutter、Tauri、React Native 和 Qt,希望可以帮助你根据项目需求做出明智的技术选型决策。
143 2
|
9月前
|
Windows
AntDesignPro使用electron构建桌面应用
AntDesignPro使用electron构建桌面应用
136 0
|
9月前
|
缓存 JavaScript 前端开发
从0到1构建跨平台Electron应用,这篇文章就够了
Electron是一个可以直接开发构建跨平台应用的库,简单、快捷。 《Electron从0到1构建跨平台应用》这篇文章,我摘录了我自己在真实项目中,从开发到生成安装包的要点。
478 0
|
9月前
|
Web App开发 开发框架 前端开发
Electron快速入手,拥有自己的第一个桌面应用
Electron 是一个跨平台的、基于 Web 前端技术的桌面 GUI 应用程序开发框架。 支持 Web 技术开发桌面应用,其本身是基于 C++ 开发的,GUI 核心来自于 Chrome,而 JavaScript 引擎使用 v8。 这使得我们使用前端技术就可以开发出属于自己的第一个桌面应用。
223 0
|
10月前
|
开发框架 Dart 数据可视化
鸿蒙全新声明式UI框架ArkUI初体验,开发应用不错,比起flutter如何
鸿蒙全新声明式UI框架ArkUI初体验,开发应用不错,比起flutter如何
|
10月前
|
开发框架 前端开发 JavaScript
构建跨平台桌面应用:Electron和Qt的比较
当谈到构建跨平台桌面应用程序时,开发人员常常会面临一个重要的选择:Electron和Qt。这两个框架都提供了强大的工具和库来开发跨平台应用程序,但它们在设计理念、技术栈和生态系统方面存在一些区别。本文将比较Electron和Qt,并探讨它们的优势和不足之处,以帮助开发人员在选择适合自己项目的框架时做出明智的决策。
3770 0
|
10月前
|
Dart Linux 开发工具
使用Flutter构建桌面应用:一次开发,多平台支持
随着移动和桌面应用程序的需求不断增长,开发人员需要寻找一种高效的方法来构建多平台的应用程序。Flutter作为一个跨平台的UI框架,提供了一次编写、多平台运行的解决方案。在本文中,我们将探讨如何使用Flutter来构建桌面应用程序,并展示其多平台支持的优势。
1585 0
|
JavaScript 前端开发 Linux
Electron入门教程1 —— 编写第一个桌面应用程序
Electron入门教程1 —— 编写第一个桌面应用程序
753 0
Electron入门教程1 —— 编写第一个桌面应用程序
|
开发框架 Dart 前端开发
如何使用 Flutter 创建桌面应用程序【Flutter 专题 1】
桌面应用程序在具有各种 UI 元素的系统窗口内运行。如果您要制作桌面应用程序,有多种不同的框架、UI 工具包和编程语言可供选择。 有两种类型的桌面应用程序开发 API:特定于平台的和跨平台的。特定于平台的 API 仅支持一种目标操作系统。例如,Cocoa API 提供了用于为 macOS 平台开发桌面应用程序的接口。另一方面,跨平台 API 允许开发人员使用单个通用 API 为多个操作系统制作桌面应用程序。
1314 0
如何使用 Flutter 创建桌面应用程序【Flutter 专题 1】
|
IDE Java Linux
为什么除了 Flutter 之外,我们还需要另一个跨平台开发框架?
不久前,谷歌正式推出Jetpack Compose 1.0 版本。近日,JetBrains 在此基础上发布了 Compose Multiplatform Alpha 版本,旨在将 Compose 扩展到桌面和 Web 端。
374 0
为什么除了 Flutter 之外,我们还需要另一个跨平台开发框架?