标签:children 维护 consumer 函数 针对 mmu 官方 title 设计
聊聊我对 react 的理解。
在 jquery 主流的时代,web 页面开发流程是通过 ajax 获取到后端数据,然后使用 jquery 生成 jquery 更新到页面中,但是随着业务发展,我们的项目可能会越来越复杂,我们每次请求到数据,或者数据有更改的时候,我们又需要重新组装一次 dom 结构,然后更新页面,这样我们手动同步 dom 和数据的成本就越来越高,而且频繁的操作 dom,也使我我们页面的性能慢慢的降低。
痛点:手动同步 dom 和数据,频繁地操作 dom。
要解决手动同步 dom 和数据的问题,这个时候 mvvm 出现了。mvvm 的双向数据绑定可以让我们在数据修改的同时去更新 dom,dom 的更新也可以直接同步到数据的更改,这个特定可以大大降低我们手动去维护 dom 更新的成本。虽然 react 属于单项数据流,但是我们可以手动实现双向数据绑定。
有了 mvvm 还不够,如果每次有数据做了更改,我们都全量更新 dom 结构的话,也没办法解决频繁操作 dom的问题。为了解决这个问题,react 内部实现了一套虚拟 dom 结构,也就是用 js 模拟的一套 dom 结构,他的作用是将真实 dom 在 js 中做一套缓存,每次有数据更改的时候,react 内部先使用算法,也就是鼎鼎有名的 diff 算法对 dom 结构进行对比,找到那些我们需要新增、更新、删除的 dom 节点,然后一次性对真实 dom 进行更新,这样就能大大降低操作 dom 的次数。
那么 diff 算法是怎么运作的呢?
:::tip 虚拟 dom 的其他优势
:::
react 设计之初是主要负责 ui 层的渲染,每个组件有自己的状态,当状态需要变化的时候,需要使用 setState 更新我们的组件。但如果我们想渲染一个组件的兄弟组件,我们就需要将组件的状态提升到父组件当中,让父组件来管理这两个组件的渲染,当我们组件的层次越来越深的时候,状态需要一直往下传,无疑加大了我们代码的复杂度,我们需要一个状态管理中心,来帮我们管理 state。
这个时候,redux 出现了,我们可以将所有的 state 交给 redux 去管理,当我们的某一个 state 有变化的时候,依赖到这个 state 的组件就会进行一次重渲染,这样就解决了我们的我们需要一直把 state 往下传的问题。redux 有 action、reducer 的概念。
通过以上规范,使得 redux 的数据流变得非常清晰,但同时也暴露出了 redux 代码的复杂,本来那么简单的功能,却需要完成那么多的代码。
后来,社区就出现了另外一套解决方案,也就是 mobx,它推崇代码简约易懂,只需要定义一个可观测的对象 store,哪个组件需要状态就进行状态注入,store 中的数据改变,会通知注入过状态的组件进行更新。
而且 mobx 内部实现了 shouldComponentUpdate 用来解决常用的性能问题,这使得我们使用 mobx 开发项目的时候可以简单快速的完成很多功能。但随着项目的不断变大,mobx 也不断暴露出了它的缺点,就是数据流太随意,不好追溯数据的流向,这个缺点正好体现出了 redux 的优点所在,所以针对于小项目来说,社区推荐使用 mo 大专栏 React-使用总结bx,对大项目推荐使用 redux。
随着 react 生态不断发展,状态管理已成为 react 生态圈必不可少的技术,react 官方也在 v16.3.0 版本上推出了自带的状态管理 API。
1 |
|
我们都知道,react 项目渲染时会分为 2 个阶段。
其中,虚拟 dom 渲染成真实 dom 的过程,这部分是 React 内置的功能,我们不需要再进行优化,所以我们探讨一下生成虚拟 dom 阶段的优化。
标签:children 维护 consumer 函数 针对 mmu 官方 title 设计
原文地址:https://www.cnblogs.com/lijianming180/p/12401965.html