React|青训营笔记

97 阅读2分钟

这是我参与「第四届青训营 」笔记创作活动的第8天

了解React

  • 2010年 Facebook 在其 php 生态中,引入了 xhp 框架,首次引入了组合式组件的思想,启发了后来的React的设计。
  • 2011年 Jordan Walke 创造了FaxJS,也就是后来的React原型:
  • 2012年在Facebook 收购 Instagram 后,该 FaxJS 项目在内部得到使用, Jordan Walke 基于 FaxJS 的经验开发出了React
  • 2013年React正式开源,在2013JsConf上Jordan Walke介绍了这款全新框架
  • 2014年后,生态大爆发,各种围绕React的新工具/新框架开始涌现

React的应用场景也很广泛,可用于前端开发、移动端开发和桌面应用开发等。

二、React的设计思路

UI编程痛点

  1. 状态更新,UI不会自动更新,需要手动地调用DOM进行更新
  2. 欠缺基本的代码层面的封装和隔离,代码层面没有组件化
  3. UI之间的数据依赖关系,需要手动维护,如果依赖链路长,则会遇到“Callback Hell”

响应式与转换式

响应式系统

事件

执行既定的回调

状态变更

前端UI

事件

执行既定的回调

状态变更

UI更新

响应式编程

  1. 状态更新,UI自动更新
  2. 前端代码组件化,可复用,可封装
  3. 状态之间的互相依赖关系,只需声明即可

组件化

组件设计

  1. 组件声明了状态和UI的映射
  2. 组件有Props/State两种状态
  3. “组件”可由其他组件拼装组成

组件化

  1. 组件内部拥有私有状态State
  2. 组件接受外部的Props状态提供复用性
  3. 根据当前的State/Props,返回一个UI

三、React的实现

Problems

  1. JSX不符合JS标准语法
  2. 返回的JSX发生改变时,如何更新DOM
  3. State/Props更新时,要重新触发render函数

Problem2

Virtual DOM(虚拟DOM)

Virtual DOM是一种用于和真实DOM同步,而在JS内存中维护的一个对象,它具有和DOM类似的树状结构,并和DOM可以建立一一对应的关系。

它赋予了React声明式的API:您告诉React希望让UI是什么状态,React就确保DOM匹配该状态。这使您可以从属性状态、事件处理和手动DOM更新这些在构建应用程序时必要的操作中解放出来。