好程序员Web前端教程之React原理解析及优化技巧
好程序员Web前端教程之React原理解析及优化技巧 , React既是当前企业选拔人才的主要技能之一 , 也是每一个Web前端人才需要掌握的知识 。 有不少同学想要快速掌握React , 接下来的好程序员Web前端学习进阶课就给大家简单介绍React原理以及相关性能优化技巧 。

文章图片
点击添加图片描述(最多60个字)编辑
ReactJS起源于Facebook内部项目 , 是一个用来构建用户界面的JavaScript库 , 相当于MVC架构中的V层框架 。 与市面上其他框架不同的是 , React把每一个组件当成了一个状态机 , 组件内部通过state来维护组件状态的变化 , 当组件的状态发生变化时 , React通过虚拟DOM技术来增量并且高效的更新真实DOM 。
React核心技术——虚拟DOM(VirtualDOM):对于每一个组件 , React会在内存中构建一个相对应的DOM树 , 基于React开发时所有的DOM构造都是通过虚拟DOM进行 , 每当组件的状态发生变化时 , React都会重新构建整个DOM数据 , 然后将当前的整个DOM树和上一次的DOM树进行对比 , 得出DOM结构变化的部分(Patchs) , 然后将这些Patchs再更新到真实DOM中 。 整个过程都是在内存中进行 , 因此是非常高效的 。
React把每个组件都当作一个状态机来维护和管理 , 因此每个组件都拥有一套完整的生命周期 , 大致可以分为三个过程:初始化、更新和销毁 。 生命周期的每一个过程都明确的反映了组件的状态变化 , 对于开发来说就能很容易的把握组件的每个状态 , 不同的状态时期做对应的事情 , 互不干扰 。
React性能优化技巧
由于React中性能主要耗费在于update阶段的diff算法 , 因此性能优化也主要针对diff算法 。
1、减少diff算法触发次数 。 减少diff算法触发次数实际上就是减少update流程的次数 , 正常进入update流程有三种方式:setState、父组件render、forceUpdate 。
2、shouldComponentUpdate 。 使用shouldComponentUpdate钩子 , 根据具体的业务状态 , 减少不必要的props变化导致的渲染 。 如一个不用于渲染的props导致的update 。 另外 , 也要尽量避免在shouldComponentUpdate中做一些比较复杂的操作 , 比如超大数据的pick操作等 。
【好程序员Web前端教程之React原理解析及优化技巧】如果你想了解更多React知识点 , 可以关注我 , 定期发布技术热点和求职指南 。 你也可以来好程序员Web前端培训班进行系统的学习进阶 , 跟随大牛讲师快速、高效的学习提升 。
推荐阅读
- 中韩季中杯A组巡礼,综合数据T1和FPX更好,大概率会携手小组出线
- RNG新上单暴露了?绿毛小明聊天记录曝光:记得照顾好我们的兄弟
- 国兵迎来好消息!50岁昔日国兵女将再次出山,曾7夺世界冠军
- 江疏影时髦穿搭合辑,好看到犯规,想“红”并不难!你爱上了吗
- 社会保险关于社保待遇,政府工作报告传递出5个好消息
- 裴秀智无ps照很真实,穿纱裙上《Vogue》,反而更美好
- 甜美还是酷盖,不好意思我两样都有,看宋祖儿穿搭,学秀腿神技
- 唐嫣也会穿错?不好驾驭的大红裙也就算了,这丝袜太难懂
- 能控制好自己情绪的人,一般修养都比较高
- 人在落魄时,别急着求人,做好这些事才有翻身的机会
