Electron入门笔记(一)-自己快速搭建一个app demo

简介: 一.安装Node 1.从node官网下载 ,最好安装.msi后缀名的文件,新手可以查看安装教程进行安装。2.然后cmd进入命令窗口,输入npm -v查看node当前版本,二.创建文件并初始化 1.

一.安装Node


 

1.从node官网下载 ,最好安装.msi后缀名的文件,新手可以查看安装教程进行安装。

2.然后cmd进入命令窗口,输入npm -v查看node当前版本,

二.创建文件并初始化


 

1.在自己喜欢的盘里新建项目文件,我是  E:\Electron\resources\app,在此文件目录app下打开命令窗口,按住shift ,右击空白处,选择在此处打开powershell命令窗口

2.在命令窗口输入:npm init,然后一直回车,直到package.json文件完成

3.在VS code中打开项目文件,新建Index.html 和mian.js,并将json文件中的主进程配置成:"main":"main.js"

4.在项目文件下安装electron :npm install electron,不建议全局安装,不使用npm install electron -g

5.在main.js文件中写入如下代码:

/******************** ** main.js文件内容 ** ********************/
 // 导入electron模块 
const electron = require('electron') 
// 应用生命控制app const app = electron.app
 // 创建一个原生浏览器窗口 
const BrowserWindow = electron.BrowserWindow 
// 引入path和URL模块
 const path = require('path') const url = require('url')
 // 保持对窗口对象的全局引用
 // 否则,窗口对象会在JS对象垃圾回收时自动关闭 
let mainWindow function createWindow () {
 // 创建浏览窗口 
mainWindow = new BrowserWindow({width: 800, height: 600})
 // 加载app的index.html文件 
mainWindow.loadURL(url.format({
 pathname: path.join(__dirname, 'index.html'), protocol: 'file:', slashes: true }))
 // Open the DevTools.打开开发者工具DevTools
 // mainWindow.webContents.openDevTools() 
// Emitted when the window is closed. 当窗口被关闭时,触发此事件 mainWindow.on('closed', function () {
 // 取消引用 window 对象,如果你的应用支持多窗口的话,
 // 通常会把多个 window 对象存放在一个数组里面,
 // 与此同时,你应该删除相应的元素。 
mainWindow = null }) } 
// Electron初始化完成,并准备好创建浏览窗口之后 
// 调用函数createWindow 
// 一些API也只有在此事件(ready)触发之后才能使用 
app.on('ready', createWindow)
 // 当所有窗口被关闭时,即事件window-all-closed被触发后,退出程序 app.on('window-all-closed', function () {
// 对于MacOS用户,往往需要使用command+q完全退出程序 
// 否则,绝大部分其菜单栏会保持激活状态。即程序并未完全退出。 
// 对于非Darwin平台来讲,如Windows,则直接退出程序
 if (process.platform !== 'darwin') { app.quit() } }) 
// 若程序activate事件被触发时,执行该操作,创建一个新窗口 
app.on('activate', function () { 
// 在Mac系统中,若其他窗口都已关闭,点击dock面板上的程序图标时 
// 会重新创建一个窗口
 if (mainWindow === null) { createWindow() } }) 
// 在这文件,你可以续写应用剩下主进程代码。 // 也可以拆分成几个文件,然后用 require 导入

6.index.html写入

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="UTF-8">
<title>Hello World!</title>
</head> 
<body> 
<h1>Hello World!</h1> 
<!-- 再次渲染进程中,你可以使用任何Node.js的API --> We are using Node.js <script>document.write(process.versions.node)</script>, Chromium <script>document.write(process.versions.chrome)</script>, and Electron <script>document.write(process.versions.electron)</script>. </body> <script> // 同样的,你也可以在此进程中引入其他文件 require('./renderer.js') </script> 
</html>

7.局部安装要在.\node_modules\.bin\目录下运行命令electron.   全局安装就在根目录文件下运行electron.

8.应用程序打包,详情可以参考官方 

9.如果想要让app代码不可见,可进行压缩,具体也可看官方文档进行操作


 

也是第一次了解学习Electron,还在摸索中,有不足可以指点一二哈。

 

 

相关文章
|
3月前
|
移动开发 开发框架 小程序
uni-app:demo&媒体文件&配置全局的变量(三)
uni-app 是一个使用 Vue.js 构建多平台应用的框架,支持微信小程序、支付宝小程序、H5 和 App 等平台。本文档介绍了 uni-app 的基本用法,包括登录示例、媒体文件处理、全局变量配置和 Vuex 状态管理的实现。通过这些示例,开发者可以快速上手并高效开发多平台应用。
109 0
|
2月前
|
Java 测试技术 持续交付
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
本文重点讲解如何搭建App自动化测试框架的思路,而非完整源码。主要内容包括实现目的、框架设计、环境依赖和框架的主要组成部分。适用于初学者,旨在帮助其快速掌握App自动化测试的基本技能。文中详细介绍了从需求分析到技术栈选择,再到具体模块的封装与实现,包括登录、截图、日志、测试报告和邮件服务等。同时提供了运行效果的展示,便于理解和实践。
123 4
【入门思路】基于Python+Unittest+Appium+Excel+BeautifulReport的App/移动端UI自动化测试框架搭建思路
|
2月前
|
移动开发 小程序 开发工具
Demo发布- ClkLog客户端集成 uni-app
在上一期推文中,我们与大家分享了 React Native 的集成 demo。本期,我们将继续介绍 ClkLog 集成 uni-app 的 demo。 uni-app 允许开发者编写一套代码,然后可以编译到 iOS、Android、H5 以及各种小程序等多个平台。因此,本次 demo 中将涵盖上述所有平台,并且我们会详细说明集成过程中遇到的难点及解决方案。
|
3月前
|
小程序 JavaScript 前端开发
uni app 入门
uni app 入门
56 2
|
4月前
|
Web App开发 Java 视频直播
FFmpeg开发笔记(四十九)助您在毕业设计中脱颖而出的几个流行APP
对于软件、计算机等专业的毕业生,毕业设计需实现实用软件或APP。新颖的设计应结合最新技术,如5G时代的音视频技术。示例包括: 1. **短视频分享APP**: 集成FFmpeg实现视频剪辑功能,如添加字幕、转场特效等。 2. **电商购物APP**: 具备直播带货功能,使用RTMP/SRT协议支持流畅直播体验。 3. **同城生活APP**: 引入WebRTC技术实现可信的视频通话功能。这些应用不仅实用,还能展示开发者紧跟技术潮流的能力。
100 4
FFmpeg开发笔记(四十九)助您在毕业设计中脱颖而出的几个流行APP
|
5月前
|
小程序 前端开发 Java
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
JavaDog Chat v1.0.0 是一款基于 SpringBoot、MybatisPlus 和 uniapp 的简易聊天软件,兼容 H5、小程序和 APP,提供丰富的注释和简洁代码,适合初学者。主要功能包括登录注册、消息发送、好友管理及群组交流。
123 0
SpringBoot+uniapp+uview打造H5+小程序+APP入门学习的聊天小项目
|
5月前
|
Web App开发 Android开发
FFmpeg开发笔记(四十六)利用SRT协议构建手机APP的直播Demo
实时数据传输在互联网中至关重要,不仅支持即时通讯如QQ、微信的文字与图片传输,还包括音视频通信。一对一通信常采用WebRTC技术,如《Android Studio开发实战》中的App集成示例;而一对多的在线直播则需部署独立的流媒体服务器,使用如SRT等协议。SRT因其优越的直播质量正逐渐成为主流。本文档概述了SRT协议的使用,包括通过OBS Studio和SRT Streamer进行SRT直播推流的方法,并展示了推流与拉流的成功实例。更多细节参见《FFmpeg开发实战》一书。
86 1
FFmpeg开发笔记(四十六)利用SRT协议构建手机APP的直播Demo
|
5月前
|
编解码 Java Android开发
FFmpeg开发笔记(四十五)使用SRT Streamer开启APP直播推流
​SRT Streamer是一个安卓手机端的开源SRT协议直播推流框架,可用于RTMP直播和SRT直播。SRT Streamer支持的视频编码包括H264、H265等等,支持的音频编码包括AAC、OPUS等等,可谓功能强大的APP直播框架。另一款APP直播框架RTMP Streamer支持RTMP直播和RTSP直播,不支持SRT协议的直播。而本文讲述的SRT Streamer支持RTMP直播和SRT直播,不支持RTSP协议的直播。有关RTMP Streamer的说明参见之前的文章《使用RTMP Streamer开启APP直播推流》,下面介绍如何使用SRT Streamer开启手机直播。
98 4
FFmpeg开发笔记(四十五)使用SRT Streamer开启APP直播推流
|
5月前
|
Java Spring
【Azure 应用服务】记一次Azure Spring Cloud 的部署错误 (az spring-cloud app deploy -g dev -s testdemo -n demo -p ./hellospring-0.0.1-SNAPSHOT.jar --->>> Failed to wait for deployment instances to be ready)
【Azure 应用服务】记一次Azure Spring Cloud 的部署错误 (az spring-cloud app deploy -g dev -s testdemo -n demo -p ./hellospring-0.0.1-SNAPSHOT.jar --->>> Failed to wait for deployment instances to be ready)
|
Web App开发 前端开发 iOS开发
开发 Electron app 必知的 4 个 tips
本文讲的是开发 Electron app 必知的 4 个 tips,Electron ,是包括 Avocode 在内的众多 app 采用的技术,能让你快速实现并运行一个跨平台桌面应用。有些问题不注意的话,你的 app 很快就会掉到“坑”里。无法从其它 app 中脱颖而出。
3504 0