25

weekly_vol008.jpg

前段时间开始学习 React,浏览官方文档时,被其中提及的一篇文章——《Give It Five Minutes》给吸引了。最开始以为是“5 分钟学会 React”这种神一般存在的教程,结果不然,它只是 37 Signal 日志 SVN(Signal v.s. Noise)中的一篇文章……可这篇文章却给了我学习 React 不可或缺的一个理由。至于原因,give me five minutes,听我细细道来。

《Give It Five Minutes》描述了作者 Jason Fried 在一次商业创新工厂演讲活动中,遇到了“Richard Saul Wurman”,因此发生了重大人生变化的故事。

事情是这样的,几年前,Jason 还是个急性子,只要是不符合作者世界观的事情,作者就会极力反驳。此外,作者也热衷于第一个发表观点和想法,似乎第一个提出来就意味着一些事儿。而这一切,都在 2007 年的一天发生了变化。

在一次商业创新工厂的会议演讲上,作者遇到了同去演讲的 Richard Saul Wurman。Richard 在作者的演讲结束后上台发表观点,在介绍完自己,并称赞了 Jason 的演讲之后,Richard 开始了自己的演讲。演讲途中,作者打断了 Richard 的发言,并对他提到的库存的一些想法提出了反对。正因为作者性急,又恰巧碰到了自己不同意的观点,所以演讲中,只要一遇到不同意 Richard 的观点,就立刻起身反驳。

而此刻的 Richard 却非常淡定,并用非常简单的一句话回应作者“Man, give it five minutes.”而正是这句话,改变了作者一生。

Richard 说有不同观点是好事儿,对不同观点进行回应也是好事儿,有坚定的想法和自己的信念更是一件好事。但是,在你确定要反驳我的观点的时候,请给我一些时间去阐明我的观点,听完我的阐述。5 分钟意味着思考,而不是马上回应(“Five minutes” represented “think”, not react)。

而这一刻,也引发了作者后续的深刻思考,并时刻提醒自己将先去思考而非快速回应作为长久的追求。

深夜读来,文章有点像鸡汤,可是,学 React 之前,一定要干了这碗鸡汤。React 挑战了很多传统的知识,很多想法,可能第一眼看上去有点不可思议,但 give it five minutes,要知道,这些看似疯狂的想法已经帮助 Facebook 和 Instagram 从里到外创建了上千的组件。

接下来几期周刊,都将以 React 为主题,层层引入,通过一个月的时间,完成对 React 的学习、升级、打怪直到自己成为 boss 的所有过程。本期,我们以社区诸位小伙伴一路走来的经验分享为重点,让你尽量快速学习 React。

5 分钟实例

首先,来看两个简单的小应用,让你预览 React 可以干嘛。

noiron - 用 React.js 写一个最简单的 To-do List 应用

通过一个简单的 To-do List 应用,让你对 React 的最基础用途——组件(component)形成基本的认识,包括组件结构、组件两种属性的传递(state 和 props)以及函数的传递,浅入浅出,对于理解 React 中的一些概念及语法很有帮助的。

defshine - 使用 React 和 Flask 开发一个留言板

通过这个应用,你会对“React 可以干嘛”有更多的了解:

  1. 组件化开发,React 提倡无状态的组件,便于重用

  2. 专注于 View,React 不是 MVC 框架,它只是一个专注于 View 的库,所以,它也可以和很多其他框架或者库一起使用

  3. 提供完成的生命周期

注:上面这两个小应用的项目分别可以在 noiron / simplest-react-todolistdefshine / message-board 查看。

快速入门

通过上面的例子,可以看出,React 其实比较好上手,即使没来得及了解细节性的知识,有时也不妨碍项目的开展。不过,正统地学习,能让你更全面地理解 React,更清晰地了解它的使用逻辑。除了 官方文档 和阮一峰老师的《React 入门实例教程》 ,以下精选的几篇文章还将丰富你的学习资料库。

布利丹牵驴子 - React 入门及资源指引

Facebook 在开源项目和软件架构方面的实力让人不得不赞叹,React 中提出的一些设计思想非常新颖,极大的简化了前端开发的代码逻辑。本文介绍 React 相关的基础知识,JSX、组件、区分 props 和 state、生命周期、事件系统……通过对这些关键内容的学习,快速开始 React 的学习之路。

whatif - Sublime Text 3 搭建 React.js 开发环境

利用 Sublime 很强的自定义功能和庞大的插件库,来,手把手式的强大开发环境搭建方案,不谢。

赖小赖小赖 - React 初探

来自 AlloyTeam 的分享,一篇文章学完所有基本特性,保入门。

zhangwang - 是时候理清 React 开发中的一些疑惑了

这篇则让你明白为什么要使用 React,以及更重要的,它所带来的改变。你从这些改变再回去看 React 为什么要设计成这样,可能会理解得更通透。

「这是一个老生常谈的问题了,比如说它的虚拟 DOM 可以被高效的渲染,比如说它有完整生命周期的“活组件”,它的组件化使得项目结构非常清晰,代码复用非常容易,比如说它的数据管理机制也能让你清晰的知晓数据的状态,而 React 本身就是被这种清晰的数据所驱动的。」

更多入门阅读

源码阅读

入门完毕,若是无法深入其内部实现机制和原理,亦会觉得不够透彻,所谓知其然更要知其所以然,接下来就从剖析 React 源码开始吧。

React 源码剖析系列 - 生命周期的管理艺术解密 setState不可思议的 React diff玩转 React Transition

本系列文章希望通过剖析 React 源码,帮助你理解其内部的实现原理。当然,阅读这一系列的文章,你需要对 React 有一定的了解,如果你还存在疑惑,请回上部分再次巩固。

JasonHuang - React Motion 缓动函数剖析

“不知道这个世界上有没有‘仿世学’,但既然动画要模仿现实世界,那么实现动画的根本方法就是借鉴上帝的办法——模拟自然规律”。本文以 React Motion 实现原理为背景,介绍一种通用的模拟物理规律的方法,以及如何使用这种方法实现 React Motion 的缓动函数。来跟着作者当一回上帝吧。

louis110 - GraphQL and Relay 浅析

GraphQL 是在 Facebook 内部应用多年的一套数据查询语言和 runtime。包括类型系统、验证、introspection,此外,还具有语法灵活、没有冗余、强类型等特征。而 Relay 则是连接 GraphQL 和 React 的一座桥梁,除了让 React 认识 GraphQL 服务器之外,还包括把关于数据获取的事情(请求异常,loading 等)都接管过来……

郭林烁_joey - 前端路由实现与 react-router 源码分析

“从点击 Link 到 render 对应 component,路由中发生了什么?”在单页应用上,前端路由并不陌生。很多前端框架也会有独立开发或推荐配套使用的路由系统。那么,当我们在谈前端路由的时候,还可以谈些什么?本文通过简要分析并实现一个的前端路由,来对 react-router 进行分析。

基本特性

JSX、Mixin、Context、Virtual DOM、react-css-modules、包react-hot-loader、react-router、Redux、Flux、relay……太多特性了,这期我们挑选其中一些基本的,分别做入门介绍。

MockingBird - 译丨React Mixin 的使用

在 React component 构建过程中,常常有这样的场景,有一类功能要被不同的 Component 公用,然后看得到文档经常提到 Mixin(混入)这个术语。此文就从 Mixin 的来源、含义、在 React 中的使用说起。

BetaRabbit - React 如何和 Server 交互

这篇讲解 React ajax 的 4 种交互方式:Root Component、Container Component、Redux/Flux Async Actions 以及 Relay,清晰明了。

小俞 - React Reflux

Reflux 是根据 React 的 Flux 创建的单向数据流类库,其单向数据流模式主要由 actions 和 stores 组成。本文会非常细致地说明如何创建 action 和 store,以及和组件的结合。

cnsnake11 - React Native 的组件架构设计

篇幅较长但不冗余的一篇文章,前半部分是目前 Flux 开源框架的一些分析,后半部分是架构设计过程。此外,还有多种方案以及完整 demo 代码提供诸位学习。

Hongchun - 深入理解 react-router 路由系统

在 web 应用开发中,路由系统是不可或缺的一部分。当前,Backbone、Ember 等主流框架都有其自己的路由器,那 react-router 相对于其他路由系统会针对 React 做了哪些优化呢?它是如何利用了 React 的 UI 状态机特性呢?又是如何将 JSX 这种声明式的特性用在路由中?本文将很好地为你揭开这些疑惑。

Coding扣钉 - 玩转 React 服务器端渲染

React 之所以让服务器端渲染变成了一件有吸引力的事情,是因为它移除了服务器端对于浏览器环境的依赖,服务器端渲染除了要解决对浏览器环境的依赖,还要解决前后端可以共享代码和前后端路由可以统一处理这两个问题。本文选择了 Redux 和 react-router 来做说明。

更多阅读

简单的应用

React 第一阶段的学习完成,一起来看几个用 React 开发的项目。上面介绍的两个只是简单实例,而下面这三个,你可以认真研究一下,以为下期的内容做好准备。

UXCore:一个兼容主流浏览器的 React PC 组件库

UXCore 是一个基于 React 的 PC UI 套件库,兼容 IE8+。

阿里巴巴信息平台是负责整个阿里巴巴集团智能办公系统的团队,涉及非常多的企业业务系统,包括薪酬、人力、财务、行政、IT 等等,在这些系统中产生了大量的表格、表单和图表的交互场景,这里面有很多重复配置的地方,也有很多定制变化的地方,目前业界的这一方面还没有能够完全满足这一方面的解决方案,因此有了 UXCore。

项目地址:https://github.com/uxcore/uxcore

一言不合造轮子 - 撸一个 ReactTimePicker

这是一个独立 React 组件,已打包成 NPM 包,涉及到 React 开发、单页测试、Webpack 等内容。

项目地址:ecmadao / react-times | 演示地址:https://ecmadao.github.io/react-times

组件化可视化图表 - Recharts

Recharts 是一款可视化组件库,为基础表格的绘制提供了另外一种可能。Recharts 含义是重新定义(Redefined)图表,这个名字的背后在于这个图表在设计上带给开发者的是不一样的体验,不仅是用 React 设计,也在于重新定义了组合与配置方式,代码更优雅,灵活可装卸。

目前版本是 0.15.1,支持 React 0.14.x 或 15.0.x 版本,现在有至少四个国外团队在产品中使用。

项目地址:recharts / recharts | 官网:http://recharts.org

专栏推荐

本期周刊特别增加专栏推荐,要深入学习 React,他们的专栏是“绕不过的三座大山”:

  • 题叶, JiyinYiyong - 题叶是社区内最早开始传播 React 的开发者,非常多的后来学习者都受到了他的影响,他在 React 和其他前端方方面面的思考,都值得去探讨

  • pure render - 由一群志同道合的开发者共同维护,分享关于 React 和 Flux 在实践中的经验与想法,篇篇精品

  • hepeguo 的专栏 - 对于 React 和 Redux 性能优化的深入研究



(本期完,接下来两期,我们将更深入 React,对 Redux/Flux、组件、Virtual DOM、React Native 以及与 webpack 等相关的所有体系,全面地整理给大家。)


往期周刊传送门:


# SegmentFault 技术周刊 #

「技术周刊」是社区特别推出的技术内容系列,一周一主题。周刊筛选的每篇内容,是作者的独到见解,踩坑总结和经验分享。

每周二更新,欢迎「关注」或者「订阅」。大家也可以在评论处留言自己感兴趣的主题,推荐主题相关的优秀文章。


SegmentFault思否
14.4k 声望168.2k 粉丝

SegmentFault 社区管理媛 - 思否小姐姐