浅谈electron构建桌面应用

1、electron是什么

electron是有Github开发, 是一个能让你使用 JavaScript, HTML 和 CSS 来创建桌面应用程序的框架。electron的原理是 通过将 Chromium 和 Node.js 组合到同一个 runtime 环境中。这些应用程序可以打包后在 macOS、Windows 和 Linux 上直接运行。

2、为什么会用electron

win:c++,c# mac:Objective-C Swift Li:c++;多个平台我们需要多个应用,高开发成本。而electron方便快捷的开发桌面应用,跨平台,对前端开发者友好,

3、目前所实现的开源软件

vscode、Atom、支付宝小程序 IDE

4、进程

渲染进程:用户看到界面由渲染进程描绘。	1个或者多个进程
主进程:运行main.js的进程,运行main.js创建web界面。1个进程

5、安装使用
eq:win >7 windows在win7以上兼容比较友好 os:10.8 mac在10.8以上

6、以已经开发的一个web系统打包成着桌面应用

一、npm install -save electron

不管你的项目是vue React 还是

项目根目录建立main.js (electron应用加载入口文件)
(main.js文件)

// 引入electron并创建一个Browserwindow
const { app, BrowserWindow } = require('electron')
const path = require('path')
const url = require('url')

// 保持window对象的全局引用,避免JavaScript对象被垃圾回收时,	窗口被自动关闭.
let mainWindow;

function createWindow() {
// 创建浏览器窗口,
mainWindow = new BrowserWindow({ width: 1920, height: 	1080 });
/*
* 加载应用----- electron-quick-start中默认的加载入口
mainWindow.loadURL(url.format({
pathname: path.join(__dirname, 'index.html'),
protocol: 'file:',
slashes: true
}))
*/
// 加载应用----适用于 react 项目
mainWindow.loadURL('http://localhost:3000/');

// 打开开发者工具,默认不打开
// mainWindow.webContents.openDevTools()

// 关闭window时触发下列事件.
mainWindow.on('closed', () => {
mainWindow = null;
});
}

// 当 Electron 完成初始化并准备创建浏览器窗口时调用此方法
app.on('ready', createWindow);

// 所有窗口关闭时退出应用.
app.on('window-all-closed', () => {
// macOS中除非用户按下 `Cmd + Q` 显式退出,否则应用与菜单栏始终处于活动状态.
if (process.platform !== 'darwin') {
app.quit();
}
});

app.on('activate', () => {
// macOS中点击Dock图标时没有已打开的其余应用窗口时,则通常在应	用中重建一个窗口
if (mainWindow === null) {
createWindow();
}
});

三、配置package.json

"main": "main.js",
"homepage": ".",  
 //Electron 调用的入口是 file :协议,/static 就会定位到根目录去
scripts:{
+ "electron-start": "electron ."
}

四、启动

yarn  start 
yarn electron-start

五、支持热更新
六、打包
#安装electron-packager包

npm install electron-packager --save-dev
#安装electron-packager命令
npm install electron-packager -g
"electron-packager": "electron-packager . 内部管理系统 	--platform=darwin --arch=x64 "

加入我的技术群,一起学习

707196135

在这里插入图片描述

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值