Electron+React+七牛云 实战跨平台桌面应用

  [复制链接]
查看5702 | 回复12 | 2019-12-11 09:42:21 | 显示全部楼层 |阅读模式
QQ截图20191211093728.png
' u. p3 f/ @  [7 {: Z- J( x3 I; C% \$ r' q4 `' Q$ }
〖课程介绍〗
/ D# z7 e  B1 C5 n6 I) h! l* S目前市场上对 Electron 的呼声很高,它几乎是 Web 开发人员开发桌面客户端的唯一途径,很多大厂都使用 Electron 开发自己的原生应用。Electron 天生适配任何前端开发框架,我们结合 React Hooks 这个炙手可热的新特性进行教学,同时因为 Electron 也可以使用 Node.js 的开发环境,所以我们同时使用七牛云和很多 Node 原生模块进行开发,来完成一个非常有吸引力的云同步 Markdown 文档管理应用。! W: A( B7 a  u9 X

& j% a% M2 i: A〖课程目录〗
( ^* h" ^! N; m+ f! c' b第1章 进入 Electron 的世界
( {. [1 P+ ]; T介绍了整个课程的背景知识,项目简介,学习流程,可以掌握的知识点,以及学习方法和前置知识。
/ U! b  A! ?! C/ O7 c6 r4 i2 P+ V  q  q1-1 学习本课程的收获以及案例展示(内附彩蛋) 试看  ?: M6 j# {, z) c! a3 g
3 P9 O8 M+ D  i) `) N& w
第2章 我们的第一个应用
2 |( }! ]- B. ^$ h1 m9 S# X; N本章讲述了 Electron 的基础用法,包括搭建 Electron 开发环境、进程和线程的知识、BrowserWindow 模块、跨进程访问等内容。4 K8 h2 E# C8 P. Q* y0 a, g
2-1 配置 Electron 开发环境 试看
( t. @  _7 l7 P( T, e7 |2-2 进程和线程+ G" Z' x0 V+ \/ @  G
2-3 主进程和渲染进程# q0 J& i( ]* G3 C* t7 Q5 p
2-4 创建 BrowserWindow
& o3 u! Y/ k% o2-5 进程间的通信
* }1 v4 J# X3 b+ a2-6 使用 IPC 进行通信
& {3 q* o+ g& m8 D7 r7 k0 f2-7 使用 remote 实现跨进程访问
+ l) _; p1 h3 b) Z, D! D* G2-8 升级到 electron 7.0 以上的注意事项
! e0 F' O$ o- z; U1 ^/ [- z, R
: @" X  t' B4 C$ u1 t4 m& W# x4 z) ~第3章 神奇的 React
6 M; \) I) b  D% {本章回顾了 React 的基础知识,从而引出了全新的 React Hooks,详细讲解了 useState、useEffect、自定义Hook 等内容。. ~+ y" Y' g7 J- J& ~- {
3-1 React 简介和缘起( J& X! W8 R- f6 I7 N& X
3-2 配置 React 开发环境..1* a1 [" q- ?5 [. Z# A& t& Y& y' n
3-3 useState Hook
9 P. T5 b; O/ W/ Q, W3-4 useEffect 不需要清除的 Effect
- J' w# x, j( ~6 y3-5 useEffect 需要清除的 Effect5 J0 X; E0 C; u1 R  F
3-6 useEffect 可控 effect3 A$ z; _/ L; b$ A: U5 }5 S
3-7 自定义 Hook(一)
0 D! k& I8 p: L, t0 k: ]5 t: Z3-8 HOC 的概念和缺点
7 r9 i" X6 l9 d* w! ~' g/ Q$ m3-9 自定义Hook(二)  G1 U; H: T7 T* a3 Q. d6 h
3-10 Hook 规则和其他 Hook( F$ T# m: T, s  ]+ R$ c% F8 B

1 T& T  a: ?- L; @5 h9 H  b第4章 双剑合璧与庖丁解牛1 x! |- X) Q7 @
本章分析了整个应用的需求,将整个应用分割成组件,然后打造一个 适配 Electron 和 React 的开发环境& x* B. l0 k; Y) Y' \
4-1 全局需求 试看
  R" p( D7 ?# w4 P$ d# b4-2 将 UI 拆分成组件
/ e' T+ J& K, @1 V- o0 I- w3 Y4-3 配置开发环境(一)
9 O% t! T; t: h' i( F+ G4-4 配置开发环境(二)/ b6 h( |0 W5 w; j2 a% }2 j
4-5 文件结构和代码规范
# y+ ^. C4 c; n! J3 u& c6 G4 P6 g% ^/ A! Q0 C* U
第5章 左侧面板开发0 a, K) y5 r6 n+ B. ?
本章开始分别开发左侧面板的各个 React 组件,同时在开发过程中选用样式库、图标库,重构公共自定义 Hook。& Y4 ~* @7 J8 F- s+ l1 C
5-1 为项目选择样式库
* v6 o0 u" f& L& r+ M$ D4 c, ?5 g5-2 FileSearch 组件(一)! e3 C- e' Q6 g& e: P
5-3 FileSearch 组件(二)
" J; S8 F6 C( V  z% F( @5-4 为项目选择图标库! V9 F5 e9 s& N! t4 S* l, X
5-5 使用 PropTypes 进行类型检查
3 W- I6 T# r) s9 z) `5-6 FileList 组件开发(一)
6 x5 a1 ]9 I1 ^9 [! m0 k5-7 FileList 组件开发(二)/ a( M% b* |" `* ^
5-8 第一个自定义 Hook - useKeyPress0 ?# Z! J9 d2 n4 V
5-9 左侧收尾工作( a  |5 M  v8 o; {
/ c' `# s2 @. Q- P7 a- z1 s# o
第6章 右侧面板开发
. m1 O) Y- T0 o; O2 }- X' N' g6 H本章开发了应用右侧的 TabList 和编辑器部分,同时在整个过程中穿插了如何选取一个好用的开源库的思路。+ T- ^2 _: t9 m7 I- S
6-1 TabList 需求和属性分析" `' f' |2 k4 c$ X
6-2 TabList 组件代码(一)
! M0 ]1 Z( k6 ~6-3 TabList 组件代码(二)
  n( a+ Z" u! A6-4 选择 MarkDown 编辑器/ v$ F1 N6 K+ z' G2 X
6-5 引入 easyMDE 编辑器
6 W$ O+ H# v% `. i! X+ Y2 z1 ]+ T# o4 `. k' P' d6 L! g
第7章 功能结合
8 b1 V: X: N& q" G9 J" N" a本章遵循 React 哲学的最后步骤,从分析应用 state 结构入手,从上至下的给应用添加状态和逻辑处理,然后提出了 flatten state 的概念, 最后用这个概念进化了整个应用的状态。1 U% g1 ?4 w0 ^) F3 x
7-1 分析设计 State 结构
( O) z* x8 r% E7-2 分析应用数据流
* j6 _# g: P/ P3 ?! u+ q7-3 给 App 组件添加状态
# W6 z% \& D! d! C7-4 添加数据处理行为(一)
. ?9 _4 F5 ]7 @9 }7-5 添加数据处理行为(二)
  c5 J0 s- r: s: r7-6 添加新建文件流程逻辑
7 z* @8 j) L$ s; w4 Z' v7-7 Flatten State 介绍
; P$ u( W# ^9 M7-8 修改 State 为 Flatten 结构编码
; `; B' y! |: \* t
0 ~4 v: m( R6 s$ ~/ [第8章 持久化保存数据
9 B0 r% V3 d6 E本章开始进入 Node.js 的世界,使用 FS 模块完成文件的增删改,同时还使用 Electron store 完成文件索引的持久化保存。
' r1 `1 V9 Y: g* F* s1 }# }8-1 在 React 中使用 Node.js
  l0 N  ]% ^+ m" r. N) A" r5 b) h/ |  l8-2 FS 模块初试牛刀
+ d* w1 m& T: X7 M* u9 {2 X- L% x8-3 FS 模块使用 Promise 改造8 [- J- F% o: l: e9 r1 y
8-4 在 App 中集成文件操作0 h5 r9 l/ t" U% @: c; p4 c% y
8-5 数据持久化解决方案
; W, f) {+ i+ z! N* w4 l# o* s2 l: G8-6 将 Electron store 集成到 App 中
9 \8 Y1 S$ p. x8-7 添加持久化数据逻辑代码
$ h* v8 I$ ?. F) [8-8 由一个 Bug 引发的思考) t( o) u3 n. l4 |# z- R
, p& E5 O& z* Y  u8 Q* b% |
第9章 Electron 锦上添花# f$ n$ |4 r" l2 }6 {/ q
本章使用 Electron 提供的模块 - Dialog、Menu、BrowserWindow 等模块进一步进化应用。在这之中,还穿插了 Node.js、DOM 遍历以及操作等一系列知识。
6 ]" \) K" r6 n( n$ t9-1 导入文件对话框(一)1 f4 O' S% R8 S$ [# A$ G
9-2 导入文件对话框(二)- Z8 I3 l; A) _7 L5 c
9-3 添加上下文菜单(一)1 u8 h8 Z4 T6 j
9-4 添加上下文菜单第二部分
/ s6 d9 K& _& @) p5 G9-5 添加上下文菜单最终实现
1 q( l. h) D- v3 P" s3 X2 P  L) Z" z9-6 原生应用菜单简介" B4 c6 w; @/ b% v. F8 C
9-7 添加原生应用菜单编码(一)
0 y" i/ u" d+ M' L( u9-8 添加原生应用菜单编码(二). Z1 I. J4 d6 a' I6 q2 m
9-9 设置窗口解决方案和流程分析, \5 Y! R$ C( d8 G+ C
9-10 添加设置窗口编码(一)& F& h! I) O5 P" ]
9-11 添加设置窗口编码(二)
5 Y! ?( M3 n5 C& l9 `/ |0 |  Z6 K$ ^5 s! F! E# D2 R
第10章 认识七牛云平台! X* {, l6 H/ L* `# f, p: p, z
本章从对象存储云平台简介开始,引出七牛云使用的流程,以及七牛云 SDK 的下载。然后使用 SDK 写一些小 Demo,最后抽象到一个云文件操作类。
4 G) y  q9 B$ Q) ?6 g) a! U10-1 对象存储平台简介
3 [, l( {) i0 j. P4 t' K10-2 七牛云平台使用简介' {' c; f1 P4 v8 S& F' H/ X, I
10-3 初始七牛 SDK% H1 W# |" X8 w5 P, q1 w- ~
10-4 云文件操作类编码(一)9 \6 B4 j7 R( A. N: Q- Z/ }) j
10-5 云文件操作类编码(二)
4 B" N% w) V; T6 s10-6 获得下载链接
( s7 t" {. D5 K# t3 ?10-7 stream 流的概念
, M- t  X+ c8 K" q+ t4 L* b10-8 stream 流的简单用法- `9 G1 }1 q( L2 N
10-9 实现文件下载方法
$ W7 H6 d9 X& k$ n& n! S0 A2 Y8 }* j) U
第11章 使用 SDK 同步到七牛云- @1 u1 E5 L$ F
本章使用上一章完成的云文件操作类将云文件同步功能添加到应用当中。4 y) K  I& B6 y
11-1 在设置窗口添加七牛云参数(一)# ^* h6 |" A) i4 j: x) B6 ]$ H: @
11-2 在设置窗口添加七牛云参数(二)2 D+ E5 B% E3 S+ L8 ~3 z( I+ u
11-3 添加云同步菜单
+ j0 @0 n( s) p  S3 ]2 i11-4 动态修改菜单项
: y5 K- E" r( w, F& s2 L11-5 自动同步单个文件至七牛云(一)
, I( m% f. L, i! F+ i# A11-6 自动同步单个文件至七牛云(二)
/ x' O1 y. P: g% H) P# f: I11-7 自动下载云文件至本地(一)
0 W9 r) }% Z* K- F/ V11-8 自动下载云文件至本地(二)
( P+ Y- r+ S# E3 t7 e4 [4 T11-9 为应用添加 Loading 效果
( L# T& I9 p$ q3 s2 i11-10 完成全部文件同步到七牛云功能编码
% U; e- g  S9 p3 ^" f( w5 C; C4 u11-11 使用流程图和伪代码解决剩下需求; m. t* w9 [! D2 x
. @, X6 ~: o% ?
第12章 应用打包与分发) w+ o/ W% y/ [4 J- e, d
本章主要以 MacOS 和 Windows 系统为例,讲解如何通过 Electron Builder 打包 Electron 应用程序。* e* \1 w6 p2 c) K8 ?3 Z
12-1 安装 Electron builder' U$ o; U* v+ L; y9 H) @; Y) h
12-2 为生产环境 build 代码
$ m7 u3 X" t6 V' g* [12-3 添加配置文件% b" Q$ d/ }" i  C2 b" t
12-4 调试整个pack流程
3 E: r- x+ e- h; r1 V! y12-5 探究打包过程和生成文件内容  ~/ g) m! N2 L. }" B+ M
12-6 生成安装包0 _- s- Q0 X6 g) d
12-7 Electron 打包体积优化第一部分- 质的飞跃* R* F. p/ F8 W) }0 U4 O, r
12-8 Electron 打包体积优化第二部分-极限优化
8 `5 j4 C+ x/ T* n9 N  P& v12-9 自动更新第一部分 - 自动发布 release
1 {  H0 n  o: {12-10 自动更新第二部分 - 添加自动更新功能% m2 B% y( ^* D& P8 f4 w/ x
12-11 自动更新 第三部分 - 本地调试自动更新功能7 `' a5 D& V6 @, d0 v
' ]8 X, M  U+ `! T
第13章 课程总结3 I! n! }" Q. s  A
本课程的回顾与总结。
: X- G8 O: z) m13-1 课程总结; t& s" |) J8 ^( C+ J
. a$ [6 I/ B, }. g+ |- x& J
〖下载地址〗
; v3 S2 k$ ]/ r4 ~- _$ o
游客,如果您要查看本帖隐藏内容请回复
- i) s8 h  q5 E# b5 g0 L

5 ~( b4 C, b0 a# D: O& A----------------华丽分割线-------------------------华丽分割线-----------------------华丽分割线-------------" S; P  s* k. j$ s# _
3 P; M, A$ V( n; v7 V: N8 G
〖下载地址失效反馈〗
0 L+ t/ M6 [5 Z) B2 H如果下载地址失效,请尽快反馈给我们,我们尽快修复。请加微信留言:22303040701 Z7 j* n+ {! Q& d
4 \9 F* E, R. _
〖升级为终身会员免金币下载全站资源〗
& M; K! X/ P7 l+ {9 l全站资源高清无密,每天更新,vip特权了解一下:http://www.mano100.cn/rjyfk_url-url.html
: c; S$ N2 i3 ^8 K6 N. {  \/ a3 V! n7 Q; L" t  V4 ^+ u
〖客服24小时咨询〗
6 y* ~; C& W/ z4 P+ h3 g) O0 x9 ?/ x& ~, s有任何问题,请点击右侧QQ邮箱:2230304070@qq.com 咨询。
回复

使用道具 举报

小小码农 | 2020-9-25 17:35:40 | 显示全部楼层
支持楼主,楼主牛逼
回复

使用道具 举报

saitama | 2021-3-7 10:34:14 | 显示全部楼层
afdsfdsfsf
回复

使用道具 举报

qwety20185 | 2021-9-15 02:43:38 | 显示全部楼层
. N) W; _4 w* k" t3 |  C" `
支持楼主,楼主牛逼
回复

使用道具 举报

modalogy | 2021-10-14 16:17:57 | 显示全部楼层
666666666666
回复

使用道具 举报

xiaoyou | 2021-10-19 18:35:38 | 显示全部楼层
支持支持支持支持支持支持
回复

使用道具 举报

lllwy | 2022-3-4 17:12:12 | 显示全部楼层
支持楼主,楼主牛逼
回复

使用道具 举报

13710858132 | 2022-4-3 20:14:45 | 显示全部楼层
666666666666666
回复

使用道具 举报

fengfengzi | 2022-5-18 18:45:22 | 显示全部楼层
ElectronElectronElectronElectronElectron
回复

使用道具 举报

newmanli1009 | 2022-6-20 05:29:13 | 显示全部楼层
爱了爱了爱了爱了
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则