博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【React进阶系列】从零开始手把手教你实现一个Virtual DOM(一)
阅读量:6266 次
发布时间:2019-06-22

本文共 1523 字,大约阅读时间需要 5 分钟。

假如你的项目使用了React,你知道怎么做性能优化吗?

你知道为什么React让你写shouldComponentUpdate或者React.PureComponent吗?
你知道为什么React让你写Immutable Data Structures吗?
你知道为什么React让你在渲染列表时,一定要给每个子项加一个key吗?
你知道为什么React让你在条件渲染时,不写if而写&&操作符或三元操作符吗?

一切的答案都在Virtual DOM上!

只要你跟着我完成了这个手写Virtual DOM的系列,上面的所有问题你都将得到解答,从此进入react高手的阵营!


现在当我们谈virtual DOM (VDOM)的时候,通常会将React捆绑在一起谈。可实际上VDOM并不是React创造的,React将这个概念拿过来以后融会贯通慢慢地成为目前前端最炙手可热的框架之一。

什么是VDOM?

首先我们都知道什么是DOM(Document Object Model),简单说就是将一个HTML文档抽象表达为树结构。VDOM则是将DOM再抽象一层生成的简化版js对象,这个对象也拥有DOM上的一些属性,比如id, class等,但它是完全脱离于浏览器而存在的。

为什么要用VDOM?

随着前端技术的发展,现在的网页应用变得越来越庞大,DOM树也随之变得复杂。当我们要修改DOM的某个元素时,我们需要先遍历找个这个元素,然后才修改能修改。而且如果我们大量地去修改DOM,每次DOM修改浏览器就得重绘(repaint)页面,有的时候甚至还得重排(reflow)页面,浏览器的重排重绘是很损耗性能的。

React是怎么用VDOM解决这个问题的呢?

  1. 首先,在React当我们要去修改数据的时候,我们会调用React提供的setState方法来修改数据;
  2. React根据新的数据生成一个新的VDOM,因为VDOM本质上只是一个普通的js对象,所以这个过程是很快的;
  3. 然后React拿着新生成VDOM和之前的VDOM进行对比(diff算法),找出不同的地方(新增,删除,修改),生成一个个的补丁(patches);
  4. 最后React把这些补丁一次性打到DOM上,完成视图的修改。

原理其实还是很直观的,但React到底是怎么用代码实现的呢?其中最关键的一步是React是怎么diff的?如果搞清楚了内部的实现原理,对于我们使用React来写出性能更高的代码至关重要。所以今天我要手把手教大家怎么从零开始实现VDOM。

我们的设计蓝图

我们将采用跟React类似的方式

  1. 使用JSX来编写组件;
  2. 用Babel将JSX转化为纯js(类似hyperscript);
  3. 将hyperscript转化成我们的VDOM;
  4. 将VDOM渲染到页面,形成真实的DOM;
  5. 手动更新数据并手动触发更新视图操作(这部分是react做的,跟VDOM的实现无关,所以我们手动模拟一下);
  6. 重复步骤二和步骤三,得到新的VDOM;
  7. diff新VDOM和旧VDOM,得到需要修改真实DOM的patches;
  8. 把patches一次性打到DOM上,只更新DOM上需要更改的地方。

图片描述

下面我们开始正式进入写代码环节,建议大家打开编辑器跟着我一步一步的敲代码。这样手把手教你敲代码的的博主你去哪里找?还不抓住这个千载难逢的机会????

项目结构

  1. index.html
  2. index.js(所有的逻辑都写在这个文件里)
  3. .babelrc(babel的配置页)
  4. package.json
  5. compiled.js (这个文件是babel打包自己生成的,不需要自己写)

大家可以新建一个目录,然后新建1-4这四个文件

转载地址:http://ducpa.baihongyu.com/

你可能感兴趣的文章
解决ssh登录Host key verification failed
查看>>
Java8新特性之二:方法引用
查看>>
记录日常Linux常用软件
查看>>
Jmeter之Bean shell使用(一)
查看>>
[翻译]利用顶点位移的VR畸变校正
查看>>
wp socket tcp链接
查看>>
asp.net 批量下载实现(打包压缩下载)
查看>>
解决了!我滴神哪!MarketPlace为什么手动下载安装部署提示invalid详解
查看>>
主成分分析原理及推导
查看>>
python中获取指定目录下所有文件名列表的程序
查看>>
HTML5的本地存储 LocalStorage
查看>>
safari和ie的时间解析(显示为NAN)
查看>>
基于 HTML5 WebGL 的挖掘机 3D 可视化应用
查看>>
Java工具创建密钥库,用于Unity 3D打包、签名、发布
查看>>
Oracle用户解锁
查看>>
MongoDB的使用
查看>>
C#开启异步 线程的四种方式
查看>>
XML解析
查看>>
2784: 【提高】小 X 与煎饼达人(flip)
查看>>
Linux 常用的压缩命令有 gzip 和 zip
查看>>