React--入门(todolist)、应用架构设计指南(技术栈)

React.js

2019-10-31、2019-11-19

学习内容:


 

一、什么是React:

  使用的人数最多;Facebook 推出;

  React Fiber:React16之后的版本

  • React是一个JavaScript库-最受欢迎的JavaScript库之一,在GitHub上超过100,000个星
  • React不是一个框架(与Angular不同,后者更自以为是)。
  • React是Facebook创建的一个开源项目。
  • React用于在前端构建用户界面(UI)。
  • React是MVC应用程序视图层(模型视图控制器)

  其中一个发生反应的最重要的方面是,你可以创建组件,这是一样的自定义,可重复使用的HTML元素,快速,高效地构建用户界面。React还使用state和props简化了数据的存储和处理方式

 

二、入门:

(1)开发环境的搭建:

  (1)先安装node.js 的环境:LTS版更稳定(建议)自带包管理工具npm

  (2)https://reactjs.org 官网,在docs Create a New React App中找到 Create React App脚手架工具创建一个原始的react工程

 

端口:http://localhost:3000/

  每次修改不需要重启服务,只需要保存后在页面上刷新 

(2)项目目录分析:

 

(1)工程入口是index.js

(2)serviceWorker.js 目前用不上,忽略

(3)index.css 的效果是把页面的边框去掉

(4)App.test.js 是jest自动化测试工具

(5)App.js 里render的html代码,就是浏览器展示的页面

(3)组件:

  html的每个标签,就是网页上的一个组件。

ReactDOM:这个库的作用是可以让我们的组件挂载到页面一个dom上,因此可以发现 App.js 在定义一个react组件

  正如index.js 中:App挂载到root dom上:

  而public的静态文档index.html中root是一个空的div

(4)JSX简单语法:

  JSX:JavaScript + XML

  JSX实际上更接近JavaScript,而不是HTML,因此在编写时需要注意一些关键区别。

  • className用于代替class添加CSS类(classJavaScript中的保留关键字)。
  • JSX中的属性和方法为camelCase- onclick将变为onClick
  • 自闭合标签必须以斜杠结尾-例如<img />

JavaScript表达式也可以使用大括号(包括变量,函数和属性)嵌入JSX内。

  jsx允许在div块中直接写js表达式,但不能写js语句例如{ { if (true) {return 123} } }

(5)编写todolist功能:

  目标:http://todolist.cn/

  详见个人文档 todolist(暂时不po出)

(6)构建和部署react应用:

  我们一直在进行即时的编译,热重载和更新。对于生产,我们将要加载静态文件-没有源代码。我们可以通过构建并部署它来做到这一点。

  如果您只想编译所有React代码并将其放在某个目录的根目录中,则只需运行以下行:

nom run build

  这将创建一个build包含您的应用程序文件夹。将文件夹的内容放在任何地方,就可以完成!

 


 

 

三、应用架构指南:

参考:https://juejin.im/post/5a46f14f6fb9a0451d41cfab#heading-0

(1)技术栈及第三方库:

以下第三方库和工具构成项目的完整技术栈:

  1. 框架:react,react-dom
  2. react路由:react-router管理应用路由;
  3. 应用状态管理容器:redux作为JavaScript状态容器react-redux将React应用与redux连接;
  4. 是否需要Immutable 数据:Immutable.js支持Immutable化状态,redux-immutable使整个redux store状态树Immutable化;
  5. 应用状态的持久化:使用redux-persist支持redux状态树的持久化,并添加redux-persist-immutable拓展以支持Immutable化状态树的持久化;
  6. 异步任务管理:使用redux-saga管理应用内的异步任务,如网络请求,异步读取本地数据等;
  7. 测试工具:使用jest集成应用测试,使用lodash,ramda等可选辅助类,工具类库;
  8. 调试工具:可选使用reactotron调试工具
项目结构图:
 

(2)组件划分:

React组件化开发原则是组件负责渲染UI,组件不同状态对应不同UI,通常遵循以下组件设计思路:

  1. 布局组件:仅仅涉及应用UI界面结构的组件,不涉及任何业务逻辑,数据请求及操作;
  2. 容器组件:负责获取数据,处理业务逻辑,通常在render()函数内返回展示型组件;
  3. 展示型组件:负责应用的界面UI展示;
  4. UI组件:指抽象出的可重用的UI独立组件,通常是无状态组件;

(3)Redux:

  Redux是一个JavaScript应用的可预测状态管理容器,它不依赖于具体框架或类库,所以它在多平台的应用开发中有着一致的开发方式和效率,另外它还能帮我们轻松的实现时间旅行,即action的回放。

 

 

  1. 数据单一来源原则:使用Redux作为应用状态管理容器,统一管理应用的状态树,它推从数据单一可信来源原则,所有数据都来自redux store,所有的数据更新也都由redux处理;
  2. redux store状态树:redux集中管理应用状态,组织管理形式就好比DOM树和React组件树一样,以树的形式组织,简单高效;
  3. redux和store:redux是一种Flux的实现方案,所以创建了store一词,它类似于商店,集中管理应用状态,支持将每一个发布的action分发至所有reducer
  4. action:以对象数据格式存在,通常至少有type和payload属性,它是对redux中定义的任务的描述;
  5. reducer:通常是以函数形式存在,接收state(应用局部状态)和action对象两个参数,根据action.type(action类型)执行不同的任务,遵循函数式编程思想;
  6. dispatch:store提供的分发action的功能方法,传递一个action对象参数
  7. createStore:创建store的方法,接收reducer,初始应用状态,redux中间件和增强器,初始化store,开始监听action

i、Redux 中间件:

  Redux中间件,它可以在action分发至任务处理reducer之前做一些额外工作dispatch发布的action将依次传递给所有中间件,最终到达reducer,所以我们使用中间件可以拓展诸如记录日志,添加监控,切换路由等功能,所以中间件本质上只是拓展了store.dispatch方法。

ii、Store 增强器:

  并不满足于拓展dispatch方法,还希望能增强store,redux提供以增强器形式增强store的各个方面,甚至可以完全定制一个store对象上的所有接口,而不仅仅是store.dispatch方法。

  其实,中间件就是以增强器方式实现的,它提供的compose方法就可以组合将我们传入的增强器拓展到store,而如果我们传入中间件,则需要先调用applyMiddleware方法包装,内部以增强器形式将中间件功能拓展到store.dispatch方法 

 

iii、react-redux库: 

  开发React应用时,需要将Redux和React应用连接起来,才能统一使用Redux管理应用状态。

 

  react-redux库提供Provider组件通过context方式向应用注入store,然后可以使用connect高阶方法,获取并监听store,然后根据store state和组件自身props计算得到新props,注入该组件,并且可以通过监听store,比较计算出的新props判断是否需要更新组件

 

(4)React路由:

 

  在React web单页面应用中,页面级UI组件的展示和切换完全由路由控制,每一个路由都有对应的URL及路由信息,我们可以通过路由统一高效的管理我们的组件切换,保持UI与URL同步,保证应用的稳定性及友好体验。

i、动态路由

  使用react-router v4版本可以定义跨平台的应用动态路由结构,所谓的动态路由(Dynamic Routing)即在渲染过程中发生路由的切换,而不需要在创建应用前就配置好,这也正是其区别于静态路由(Static Routing)所在,动态路由提高更灵活的路由组织方式,而且更方便编码实现路由按需加载组件。

 

React Router是完整的React 路由解决方案:

  1. 声明式:语法简洁,清晰;
  2. 按需加载:延迟加载,根据使用需要判断是否需要加载;
  3. 动态路由:动态组合应用路由结构,更灵活,更符合组件化开发模式;

ii、react-router-dom:

 

  同时使用React-Router和Redux时,大多数情况是正常的,但是也可能出现路由变更组件未更新的情况,要解决这个问题只需要简单的使用react-router-dom提供的withRouter方法包裹组件

iii、整合redux和路由:(更应该使用: connected-react-router

  在使用Redux以后,需要遵循redux的原则:单一可信数据来源,即所有数据来源都只能是reudx store,react路由状态也不应例外,所以需要将路由state与store state连接。

  (官方文档中提到的是 react-router-redux,并且它已经被整合到了 react-router v4 中,但是根据 react-router-redux 的文档,该仓库不再维护,推荐使用 connected-react-router。)

https://juejin.im/post/5b4de4496fb9a04fc226a7af#heading-13

 

 

(5)redux持久化:

  在开发的过程中,数据用redux管理,觉得希望将数据持久化保存,也就是说当用户下一次打开app或网站的时候,我们希望浏览器/APP自动加载出上次的数据,怎么办?-- 持久化

redux-persist库

  官方示例代码:

 

 

  如果你使用的是react,使用 PersistGate 包裹根组建。这将延迟渲染app UI直到持久化状态取回并保存到redux中。

 

(6)异步任务流管理:

  在应用开发过程中,最主要的异步任务就是数据HTTP请求,所以我们讲异步任务管理,主要关注在数据HTTP请求的流程管理。

redux-saga

  redux-saga是一个致力于使应用中如数据获取,本地缓存访问等异步任务易于管理,高效运行,便于测试,能更好的处理异常的三方库。

  Redux-saga是一个redux中间件,它就像应用中一个单独的进程,只负责管理异步任务,它可以接受应用主进程的redux action以决定启动,暂停或者是取消进程任务,它也可以访问redux应用store state,然后分发action

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2019-11-01 20:09  Marvin_Tang  阅读(716)  评论(0编辑  收藏  举报