【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

2019 年 React 学习路线图

  • 2018-12-21
  • 本文字数:3162 字

    阅读完需:约 10 分钟

2019年React学习路线图

之前我们已经介绍了2019年Vue学习路线图,而 React 作为当前应用最广泛的前端框架,在 Facebook 的支持下,近年来实现了飞越式的发展,所以,我们将在下文中介绍 2019 年 React 学习路线图,希望给想学 React 的开发者一些借鉴。


这就是 2018 年的 React 路线图。它非常全面,2018 年剩下的时间可能不够你学会所有这些,但不要担心,所有的技术在 2019 年仍然有效。



图片来源:https://github.com/adam-golab/react-developer-roadmap/blob/master/roadmap.png

1. 基础知识

不管你要学习哪个 Web 开发框架或库,都必须掌握基础知识,如 HTML、CSS 和 JavaScript,这三个是 Web 开发的三大支柱。

HTML

HTML 是 Web 开发人员最重要的技能之一,因为它为网页提供了基本结构。

CSS

CSS 用于设置网页样式,让网页看起来更好看。

JavaScript

JavaScript 让网页具备交互性。React 是基于 JavaScript 的,因此在学习 React 之前,你应该先了解 JavaScript。

2. 通用的开发技能

无论你是前端开发人员还是后端开发人员,甚至是全栈工程师,都必须了解一些能够让你在编程世界中生存下来的通用开发技能。

学习 GIT

你必须在 2018 年完全了解 Git。尝试在 GitHub 上创建一些存储库,与其他人共享你的代码,并学习如何在你喜欢的 IDE 中克隆 Github 上的代码。

了解 HTTP(S)协议

如果你想成为一名 Web 开发人员,那么了解 HTTP 绝对是有必要的。


我不是要你去阅读 HTTP(S)规范,但你至少应该熟悉常见的 HTTP 请求方法,如 GET、POST、PUT、PATCH、DELETE、OPTIONS 以及 HTTP/HTTPS 的工作原理。

学习终端

虽然前端开发人员学习 Linux 或终端并不是强制性的,但我强烈建议你熟悉以下终端,了解如何配置你的 shell(bash、zsh、csh)等。

算法和数据结构

好吧,这又是一个通用编程技能,成为 React 开发者不一定需要了解这些,但要成为真正的程序员,这是必备技能。

学习设计模式

就像算法和数据结构一样,成为 React 开发者并不一定要学习设计模式,但学好设计模式会让你变得更好。了解设计模式将帮你找到能够经受住时间考验的解决方案。

3.学习 React

你必须学好 React 才能成为一名 React 开发者。学习 React 最好的资源是它的官方网站,但作为初学者,它对你来说可能有点难。

3.1 学习构建工具

如果你想成为一名专业的 React 开发者,那么你应该花一些时间熟悉一下你将作为 Web 开发者需要使用的工具,比如构建工具、单元测试工具、调试工具等。


以下是路线图中列出的构建工具:


包管理器:


  • npm

  • yarn

  • pnpm

  • 任务执行器

  • npm 脚本

  • gulp

  • WebPack

  • Rollup

  • Parcel


顺便说一句,并非要学习所有这些工具,对于初学者来说,学习 npm 和 Webpack 应该足够了。在你对 Web 开发和 React 生态系统有了更多的了解后,你就可以学习其他工具。

3.2 样式

如果你的目标是成为 React 开发者,了解一些样式相关的知识只会有益无害。路线图中提到了很多 CSS 相关的东西,比如 CSS 预处理器、CSS 框架、CSS 架构和 JS 中的 CSS。


我建议你至少学习一下 Bootstrap,这是你经常会用到的 CSS 框架。


如果你想进一步学习 bootstrap,也可以学习 Materialise 或 Material UI。

3.3 状态管理

这是 React 开发者应该关注的另一个重要领域。路线图中提到了以下一些需要掌握的概念和框架:


  • 组件 State/ContextAPI

  • Redux

  • 异步操作(副作用)

  • Redux Thunk

  • Redux Better Promise

  • Redux Saga

  • Redux Observable

  • Helpers

  • Rematch

  • Reselect

  • Data persistence

  • Redux Persist

  • Redux Phoenix

  • Redux Form

  • MobX


如果东西太多,我建议你只关注 Redux。

3.4 Type Checker

由于 JavaScript 不是一种强类型语言,因此编译器不会捕获那些与类型相关的错误。


随着应用程序的增长,你可以通过类型检查捕获大量错误,尤其是如果你可以使用 Flow 或 TypeScript 等 JavaScript 扩展对整个应用程序进行类型检查。


React 也提供了一些内置的类型检查功能,可以用它们帮你尽早发现 bug。


由于 Angular 也使用了 TypeScript,我认为可以同时学习 JavaScript 和 TypeScript。

3.5 Form Helper

除了 Type Checker 之外,还可以学习像 Redux Form 这样的 Form Helper,它提供了在 Redux 中管理表单状态的最佳方法。除了 Redux Form 之外,还有 Formik、Formsy 和 Final。

3.6 路由

组件是 React 声明性编程模型的核心,而路由组件是应用程序的重要组成部分。


React Router 提供了一组导航组件,这些组件可以通过声明的方式与你的应用程序组合在一起。


除了 React Router 之外,你还可以看看 Router 5 和 Redux-First Router。

3.7 API 客户端

在今天的世界中,你很少会构建独立的 GUI,相反,你将有更多机会使用 REST 和 GraphQL 等 API 构建与其他应用程序发生交互的东西。


值得庆幸的是,React 开发者可以使用很多 API 客户端:


REST


  • Fetch

  • SuperAgent

  • axios


GraphQL


  • Apollo

  • Relay

  • urql


Apollo 客户端是我的最爱,它提供了一种使用 GraphQL 构建客户端应用程序的简便方法。Apollo 可以帮你快速构建使用 GraphQL 获取数据的 UI,并可以与任意 JavaScript 前端一起使用。

3.8 辅助库

这些库可以让你的工作变得更轻松。React 开发人员可以使用很多辅助库,如下所示:


  • Lodash

  • Moment

  • classnames

  • Numeral

  • RxJS

  • Ramda


这些不一定都要学,路线图中的 Lodash、Moment 和 Classnames 是用黄色标注的,所以应该先从它们开始学习。

3.9 测试

测试是 React 开发者的一项重要技能,但经常被忽视,如果你想在竞争中保持领先,就要学习一些用于测试的库。这些库可用于单元测试、集成测试和端到端测试。


以下是路线图中提到的库:

单元测试

  • Jest

  • Enzyme

  • Sinon

  • Mocha

  • Chai

  • AVA

  • Tape

端到端测试

  • Selenium, Webdriver

  • Cypress

  • Puppeteer

  • Cucumber.js

  • Nightwatch.js

集成测试

  • Karma


你可以学习你想学习的库,但建议一定要学习 Jest 和 Enzyme。

3.10 国际化

这是前端开发的另一个重要主题。你可能需要支持日本、中国、西班牙和其他欧洲国家的本地 GUI 版本。


 路线图中建议你学习以下技术,它们都很好理解:


  • React Intl

  • React i18next


这两个库都提供了 React 组件和 API 来格式化日期、数字和字符串,包括复数和处理翻译。

3.11 服务器端渲染

你可能会想,服务器端渲染和客户端渲染之间有什么区别。在使用客户端渲染时,你的浏览器会下载一个最小的 HTML 页面,然后通过 JavaScript 并将内容填充到页面中。


在使用服务器端渲染时,React 组件是在服务器上进行渲染的,将输出的 HTML 内容传到客户端或浏览器。


路线图推荐了以下的服务器端渲染:


  • Next.js

  • After.js

  • Rogue


不过我建议学习 Next.js 应该足够了,Max 的“ React 16 — The Complete Guide”也涵盖了 Next.js 的基础知识。

3.12 静态站点生成器

Gatsby.js 是一个现代静态站点生成器。你可以使用 Gatsby 创建个性化的登录网站体验。它将你的数据与 JavaScript 相结合,并创建格式良好的 HTML 内容。

3.13 后端框架集成

React on Rails 将 Rails 与 Facebook 的 React 前端框架(服务器渲染)集成在一起。它提供了服务器渲染,通常用于 SEO 爬虫索引和 UX。

4.移动端

React Native 正迅速成为使用 JavaScript 开发具有原生外观的移动应用程序的标准方法。


路线图中建议你学习以下库:


  • React Native

  • Cordova/PhoneGap


但我认为只要学习 React Native 就足够了。

5.桌面端

还有一些基于 React 的框架可用于构建像 React Native Windows 这样的桌面 GUI,让你可以使用 React 构建原生 UWP 和 WPF 应用程序。


路线图建议使用以下几个库:


  • Proton Native

  • Electron

  • React Native Windows


它们都是进阶的内容,如果你已经掌握了 React,可以看一下它们。

6.虚拟现实

如果你对构建基于虚拟现实的应用程序感兴趣,还可以了解以下像 React 360 这样的框架,让你可以通过 React 开发 VR 体验。如果你对这个领域感兴趣,可以进一步了解 React 360。


更多内容,可关注前端之巅(ID:frontshow)



英文原文:


https://hackernoon.com/the-2018-react-js-roadmap-4d0a43814c02


公众号推荐:

跳进 AI 的奇妙世界,一起探索未来工作的新风貌!想要深入了解 AI 如何成为产业创新的新引擎?好奇哪些城市正成为 AI 人才的新磁场?《中国生成式 AI 开发者洞察 2024》由 InfoQ 研究中心精心打造,为你深度解锁生成式 AI 领域的最新开发者动态。无论你是资深研发者,还是对生成式 AI 充满好奇的新手,这份报告都是你不可错过的知识宝典。欢迎大家扫码关注「AI前线」公众号,回复「开发者洞察」领取。

2018-12-21 10:386545
用户头像

发布了 731 篇内容, 共 433.7 次阅读, 收获喜欢 1997 次。

关注

评论 3 条评论

发布
用户头像
涨知识
2019-02-22 15:36
回复
用户头像
有如此长虫在人间作乱,应尽快杀之
2018-12-25 13:46
回复
没有更多了
发现更多内容

“千言”开源数据集项目全面升级:数据驱动AI技术进步

百度大脑

人工智能

在线JSON转HTML,TABLE表格工具

入门小站

工具

多种网络设备的优缺点及网络故障的排除方法

恒生LIGHT云社区

故障 网络设备

Dumpling 导出表内并发优化丨TiDB 工具分享

PingCAP

Greenplum 内核源码分析 - 分布式事务 (五)

王凤刚(ginobiliwang)

源码分析 greenplum 分布式式事务

Linux之目录结构

入门小站

带你认识传统语音识别技术

华为云开发者联盟

语音识别 语言模型 声学模型 隐马尔可夫链 WFST解码

docker

Docker jenkins pipeline

【直播预告】全国人工智能大赛赛题讲解直播来啦!1月6日晚20点,不见不散!

OpenI启智社区

人工智能大赛

微信小程序获取位置信息

程思扬

小程序 小程序云开发 开发者 开发 小程序生态

甲方,你们愿意被乙方侮辱吗?

码农一米

云计算 云服务

百度飞桨EasyDL桌面版正式上线,没网也能训练AI!

百度大脑

人工智能

阿里巴巴集团副总裁贾扬清-一个AI开发者的奇幻漂流

大咖说

前端培训:React Native 开发过程中遇到的坑

@零度

前端开发 ​React Native

Java开发之SSM框架整合配置知识分享

@零度

ssm JAVA开发

React 中五种常见的使用样式

编程江湖

React

VRAR产业峰会暨第二届华为VR开发应用大赛颁奖典礼在和平区成功举办!

华为云开发者联盟

云计算 5G AR 华为云 vr

Stellantis集团将于2022CES展期间召开网络直播发布会

InfoQ_967a83c6d0d7

大数据培训:hadoop中shuffle过程面试题

@零度

大数据 hadoop Shuffle

云计算厂商们,你们辜负了中国的用户

码农一米

云计算 云服务

如何解决JDBC死链接导致NIFI线程假死

编程江湖

自创解法!setTimeout+Promise+Async输出顺序?简单的一匹!!

Sunshine_Lin

面试 前端 ES6 Promise Async

绥北人民法院:用宜搭打造“线上法庭”,让群众少跑腿

一只大光圈

低代码 数字化转型 法院 钉钉宜搭

HBase 优化如何操作

编程江湖

HBase

使用APICloud开发app的性能提升实践

YonBuilder低代码开发平台

android APP开发 APICloud 跨端开发 app性能

基于机器学习和TFIDF的情感分类算法,详解自然语言处理

华为云开发者联盟

自然语言处理 机器学习 算法 TFIDF 情感分类

安装VTK配置出现错误

Ayosh

qt

2021年度总结,欲望反光

程思扬

经验分享 #总结# 经验总结 盘点 2021

书单 | 2021年度经典畅销佳作盘点!

博文视点Broadview

网络安全好学吗?手把手教你学metasploit 网络安全工程师学习资料汇总

学神来啦

惟客数据“惟客云”升级:稳操胜“券”,助力商家精准营销

科技热闻

2019年React学习路线图_大前端_javinpaul_InfoQ精选文章