分享Webpack+Electron+React笔记_惠州前端培训学校
作者:alu发布时间:2022-03-18分类:前端开发专业浏览:669
下面惠州北大青鸟老师给大家分享一下Webpack+Electron+React笔记,希望对大家有帮助。
看惯了网上各种全家桶,各种X+Y+Z,今天我也来凑凑热闹,和大家一起聊一聊如何使用Webpack打包基于Electron+React开发的跨平台桌面应用。
Electron是一个结合Node.js和Chromium实现的跨平台桌面应用解决方案,提供了操作系统访问Api,并赋予普通HTML网页访问Node.js本地模块的能力。使得掌握传统HTML、CSS和JS等技术的前端开发工程师,可以轻松的开发本地桌面应用。由于Electron基于Node.js,而Node.js本身具备跨平台特性,因此基于Electron开发的桌面应用程序也具备很好的跨平台能力,可以很好的适配Windows、MacOS和Linux等操作系统。
Electron除了支持几乎全部的Node.js功能,还提供很多内置模块,这些模块大致可以分为三类:仅供主进程使用的主进程模块(如:app,ipcMain等)、仅供渲染进程使用的渲染进程模块(如:ipcRenderer等),以及可以同时供主进程和渲染进程引用的模块,我称之为公共模块(如:clipboard等)。
一个Electron应用的入口文件通常被命名为main.js,主要负责整个应用的生命周期管理,以及主进程任务的分发等。
123456789101112131415161718192021
const { app, BrowserWindow } = require('electron');let win;const createWindow = () => { win = new BrowserWindow({width:
800, height: 600}); const indexPageURL = `file://${__dirname}/index.html`;
win.loadURL(indexPageURL); win.on('closed', () => { win = null; });
}app.on('ready', createWindow);app.on('window-all-closed',
() => { if (process.platform !== 'darwin') { app.quit(); }});app.on('activate', () => { if (!win) { createWindow(); }});
我们先来看一个最基础的Electron应用实例:
如前文所述,Electron是使用我们前端开发工程师所熟知的HTML、CSS和JS来开发桌面应用,自然我们就可以使用各种前端框架和打包工具来开发和管理我们的Electron应用,比如接下来即将讲述的Webpack+React。
现如今前端开发越来越趋向于单页应用,很多工具也都提供了打包单页应用的功能,特别是在移动端页面中,单页应用更是盛行。但是在Electron应用中却更适合选择比较传统的多页面模式。因为,在桌面应用中多以窗口的形态存在,每个窗口就对应一个完整的界面,而在Electron中,一个界面就可以对应一个HTML页面。
现在,我们来搭建一个Webpack+React多页面应用。
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
const path = require('path');const htmlPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('mini-css-extract-plugin');
const outputPath = path.resolve(__dirname, '../dist');
module.exports = { entry: { index: path.resolve(__dirname, '../app/pages/index.js'), login:
path.resolve(__dirname, '../app/pages/login.js') }, output: { path: outputPath, filename:
'js/[name].js', chunkFilename: 'js/[name].bundle.js' }, module:
{ rules: [{ test: /\.(js|jsx)$/, use: { loader: "babel-loader",
options: { presets: ["es2015", "react", "stage-0"] } }, exclude:
/node_modules/ }, { test: /\.(css|less)$/, use: [ { loader:
ExtractTextPlugin.loader, options: { publicPath: outputPath + '/css' } },
{loader: 'css-loader'}, {loader: 'less-loader'} ] },
{ test: /\.(png|jpe?g|gif)/, use: [{ loader: 'url-loader',
options: { limit: 8192, name: 'images/[name].[ext]', publicPath:
outputPath } }] } ] }, plugins: [ new htmlPlugin({ title: 'Index',
template: 'app/tpl.html', chunks: ['common', 'index'],
chunksSortMode: 'manual', filename: 'index.html' }),
ew htmlPlugin({ title: 'Login', template: 'app/tpl.html',
chunks: ['common', 'login'], chunksSortMode: 'manual', filename: 'login.html' }),
ew ExtractTextPlugin({ filename: "css/[name].css", chunkFilename: "css/[id].css" }) ]};
简单说明一下,为了使用一些最新的特性,而现在的浏览器内核并没有完全支持这些新特性,因此我们通常需要使用babel-loader来进行转义,让我们的新特性在现在的浏览器中可以正常运行。因此,我们需要安装babel、babel-loader、以及es2015、react以及stage-0等辅助插件。当然,兼容程度可以根据自己的情况设置,设置state-0/1/2/3都可以。
另外,为了更好的编写和维护CSS样式,我们通常会使用LESS、SCSS等预编译语言,而且为了尽量减小前端整体资源大小,通常我们还会对JS、CSS进行压缩,因此我们还需要:less-loader、css-loader、style-loader和mini-css-extract-plugin等插件。
最后就是处理我们在界面布局过程中使用到的图标、图片文件,因此再加上url-loader和file-loader,基本功能就完成了。
接下来,我们再把React和Electron整合起来,一个Webpack+Electron+React的基本应用模型就搭建好了。
首先要做的就是让Webpack打包配置支持Node.js模块,因为Node.js模块不存在于node_modules中,如果直接使用以上配置文件打包,会出现类似报错:
123456
ERROR in ./node_modules/electron/index.jsModule not found: Error:
Can't resolve 'fs' in '/Users/YS/Desktop/webpack-electron/node_modules/electron' @ .
/node_modules/electron/index.js 1:9-22 @ ./app/components/Login/index.js @ ./app/pages/login.js ...
所幸,Webpack早就考虑到了此类问题,并且提供了target配置项,用于指定打包的目标应用类型。比如眼下我们要打包Electron应用,就需要将target设置为electron-renderer。
123
module.exports = { target: 'electron-renderer'};
然后,便是要考虑开发环境与生产环境的区别,为这两种环境设置不同的模式。
最后我们将前面的内容整合起来,便可得出一个基础的Electron应用的开发模板。
想学前端,可以来惠州北大青鸟新方舟校区详细了解。
标签:惠州前端培训学校惠州前端基础惠州前端培训北大青鸟IT计算机学校北大青鸟IT软件学校前端北大青鸟IT学校惠州北大青鸟北大青鸟
- 前端开发专业排行
- 标签列表
-
- Java (3694)
- 北大青鸟 (3713)
- 软件开发 (3613)
- JAVA (3413)
- UI设计入门 (2093)
- 惠州北大青鸟 (4375)
- 惠州IT培训 (2558)
- UI设计培训 (2090)
- 惠州UI设计培训 (2095)
- 惠州UI设计培训学校 (2090)
- 惠州计算机软件培训 (6260)
- 惠州计算件软件开发 (6260)
- 惠州计算机软件基础 (6261)
- 惠州计算机JAVA培训 (3574)
- 惠州计算机Java软件开发 (3620)
- 惠州计算机JAVA软件开发 (4645)
- 惠州计算机JAVA软件开发学校 (3338)
- 惠州计算机Java软件开发培训 (3338)
- 北大青鸟IT计算机学校 (5048)
- 北大青鸟IT软件学校 (5062)
- 北大青鸟IT学校 (5059)
- 惠州计算机UI设计软件开发 (2088)
- UI设计基础教程 (2088)
- UI设计是什么 (2088)
- UI设计教程 (2088)
- 网站分类
-
- 计算机教程
- 计算机入门
- 职业学校
- 新闻动态
- 专业课程
- 热门技术
- SEO
- 培训教程
- windows
- linux教程
- 系统集成
- 网站开发
- Html5
- 办公软件
- 师资力量
- 热点问答
- 联系我们
- 计算机学校
- 惠州计算机学校
- 河源计算机学校
- 广州计算机学校
- 深圳计算机学校
- 湛江计算机学校
- 佛山计算机学校
- IT计算机培训信息
- 设计专业
- UI
- 影视特效
- 游戏动漫设计
- Photoshop
- AI设计
- 软件教程
- Java技术
- C语言/C++语言培训
- C#
- Python技术
- PHP
- 数据库
- SQL Server
- 网络教程
- 网络安全
- 网络营销
- 软件专业
- 大数据专业
- 前端开发专业
- 软件测试专业
- Python专业
- 软件实施
- 珠海计算机学校
- 初中生学什么好
- 计算机认证
- 文章归档
-
- 2024年11月 (14)
- 2024年10月 (32)
- 2024年9月 (29)
- 2024年8月 (68)
- 2024年7月 (59)
- 2024年6月 (43)
- 2024年5月 (48)
- 2024年4月 (80)
- 2024年3月 (65)
- 2024年2月 (54)
- 2024年1月 (25)
- 2023年12月 (12)
- 2023年11月 (73)
- 2023年10月 (134)
- 2023年9月 (34)
- 2023年8月 (3)
- 2023年7月 (3)
- 2023年6月 (12)
- 2023年5月 (30)
- 2023年4月 (72)
- 2023年3月 (11)
- 2023年2月 (34)
- 2023年1月 (37)
- 2022年12月 (78)
- 2022年11月 (359)
- 2022年6月 (1193)
- 2022年5月 (570)
- 2022年4月 (1567)
- 2022年3月 (982)
- 2022年2月 (54)
- 2022年1月 (182)
- 2021年9月 (308)
- 2021年8月 (1704)
- 2021年7月 (2423)
- 2021年6月 (1806)
- 2021年5月 (1569)
- 2021年4月 (1380)
- 2021年3月 (1255)
- 2021年2月 (709)
- 2021年1月 (1521)
- 2020年12月 (3626)
- 2020年11月 (1646)
- 2020年10月 (1046)
- 2020年9月 (592)
- 最近发表
-
- 清远信息:2024年广清杯清远南粤家政技能大赛举行决赛|||计算机培训机构
- 汕尾信息:陈良川带队到汕尾技师学院调研|||计算机职业技能培训班
- 东莞信息:凤岗凤岗镇组织召开社保参保缴费及劳动用工政策宣讲会|||计算机软件培训学校
- 阳江信息:2024年度注册城乡规划师职业资格考试的合格标准是怎样的?|||计算机软件培训学校
- 阳江信息:职业技能提升补贴对象有哪些?|||大学生计算机培训学校
- 清远信息:清远市首家社保服务合作网点在清城区举办启动仪式|||计算机职业技能培训班
- 汕头信息:招聘658名中高端人才!2024年汕头市引进中高端人才专场招聘会举行|||北大青鸟计算机培训中心
- 东莞信息:广东省社保智能经办现场会在东莞召开|||大学生计算机培训学校
- 东莞信息:东坑镇举办2024年重点群体系列招聘活动|||计算机职业技能培训班
- 东莞信息:万江万江街道成功举办第四届粤菜师傅烹饪技能竞赛|||广州计算机编程培训