详解操作虚拟dom模拟react视图渲染


Posted in Javascript onJuly 25, 2018

1.为什么要使用虚拟dom?

网页性能优化->尽量少操作DOM

2..虚拟DOM(Virtual DOM) VS js直接操作原生DOM(innerHTML)

function Raw() {
  var data = _buildData(),
    html = "";
  ...
  for(var i=0; i<data.length; i++) {
    var render = template;
    render = render.replace("{{className}}", "");
    render = render.replace("{{label}}", data[i].label);
    html += render;
  }
  ...
  container.innerHTML = html;
  ...
}

以下测试用例中虽然构造了一个包含1000个Tag的String,并把它添加到DOM树中,但是只做了一次DOM操作。然而,在实际开发过程中,这1000个元素更新可能分布在20个逻辑块中,每个逻辑块中包含50个元素,当页面需要更新时,都会引起DOM树的更新,上述代码就近似变成了如下格式:

function Raw() {
  var data = _buildData(), 
    html = ""; 
  ... 
  for(var i=0; i<data.length; i++) { 
    var render = template; 
    render = render.replace("{{className}}", ""); 
    render = render.replace("{{label}}", data[i].label); 
    html += render; 
    if(!(i % 50)) {
      container.innerHTML = html;
    }
  } 
  ... 
}

实际场景:实际是一个组件里经常包含多个局部视图,小小的状态变更都要重新构造整棵 DOM,性价比太低。需要更新页面较多局部视图的时候,这样的做法不可取。

3.MVVM模式和React的模板引擎。

  1. MVVM: Model-View-ViewModel MVVM 可以很好的降低我们维护状态 -> 视图的复杂程度(大大减少代码中的视图更新逻辑)。MV*模式:只要在模版中声明视图组件是和什么状态进行绑定的,双向绑定引擎就会在状态更新的时候自动。
  2. React渲染视图原理:React setState之后会将传入的参数对象与组件当前的状态合并,React 会以相对高效的方式根据新的状态构建 React 元素树并且着手重新渲染整个UI界面。React 会自动计算出新的树与老树的节点差异,然后根据差异对界面进行最小化重渲染。

4.Virtual DOM模拟ReactJS视图渲染大致逻辑:

// 1. 构建虚拟DOM
var tree = el('div', {'id': 'container'}, [
  el('h1', {style: 'color: blue'}, ['simple virtal dom']),
  el('p', ['Hello, virtual-dom']),
  el('ul', [el('li')])
])

// 2. 通过虚拟DOM构建真正的DOM
var root = tree.render()
document.body.appendChild(root)

// 3. 生成新的虚拟DOM
var newTree = el('div', {'id': 'container'}, [
  el('h1', {style: 'color: red'}, ['simple virtal dom']),
  el('p', ['Hello, virtual-dom']),
  el('ul', [el('li'), el('li')])
])

// 4. 比较两棵虚拟DOM树的不同
var patches = diff(tree, newTree)

// 5. 在真正的DOM元素上应用变更
patch(root, patches)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 对Select的操作备忘记录
Jul 04 Javascript
javascript游戏开发之《三国志曹操传》零部件开发(五)可移动地图的实现
Jan 23 Javascript
基于BootStrap Metronic开发框架经验小结【八】框架功能总体界面介绍
May 12 Javascript
JavaScript常用正则验证函数实例小结【年龄,数字,Email,手机,URL,日期等】
Jan 23 Javascript
BootStrap 弹出层代码
Feb 09 Javascript
js模仿微信朋友圈计算时间显示几天/几小时/几分钟/几秒之前
Apr 27 Javascript
Angular指令之restict匹配模式的详解
Jul 27 Javascript
Bootstrap table使用方法记录
Aug 23 Javascript
webpack打包node.js后端项目的方法
Mar 10 Javascript
在 Vue 项目中引入 tinymce 富文本编辑器的完整代码
May 04 Javascript
JS/HTML5游戏常用算法之路径搜索算法 A*寻路算法完整实例
Dec 14 Javascript
在vue中import()语法不能传入变量的问题及解决
Apr 01 Vue.js
浅析JS中回调函数及用法
Jul 25 #Javascript
详解使用mpvue开发github小程序总结
Jul 25 #Javascript
详解mpvue开发小程序小总结
Jul 25 #Javascript
Bootstrap table表格初始化表格数据的方法
Jul 25 #Javascript
JS实现用特殊符号替换字符串的中间部分区域的实例代码
Jul 24 #Javascript
微信小程序实现图片上传放大预览删除代码
Jun 28 #Javascript
vue实现底部菜单功能
Jul 24 #Javascript
You might like
PHP提取中文首字母
2008/04/09 PHP
Zend的AutoLoad机制介绍
2012/09/27 PHP
PHP 数据结构队列(SplQueue)和优先队列(SplPriorityQueue)简单使用实例
2015/05/12 PHP
学习ExtJS fit布局使用说明
2009/10/08 Javascript
YUI Compressor压缩JavaScript原理及微优化
2013/01/07 Javascript
通过AJAX的JS、JQuery两种方式解析XML示例介绍
2013/09/23 Javascript
nodeType属性返回被选节点的节点类型介绍
2013/11/22 Javascript
javascript定义变量时加var与不加var的区别
2014/12/22 Javascript
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
javascript每日必学之循环
2016/02/19 Javascript
非常棒的jQuery图片轮播效果
2016/04/17 Javascript
JS获取和修改元素样式的实例代码
2016/08/06 Javascript
jQuery+ajax的资源回收处理机制分析
2017/01/07 Javascript
webpack学习笔记之代码分割和按需加载的实例详解
2017/07/20 Javascript
使用D3.js制作图表详解
2017/08/13 Javascript
浅谈webpack打包过程中因为图片的路径导致的问题
2018/02/21 Javascript
vue.js的computed,filter,get,set的用法及区别详解
2018/03/08 Javascript
vue.js内置组件之keep-alive组件使用
2018/07/10 Javascript
谈谈JavaScript令人迷惑的==与+
2020/08/31 Javascript
Python自动连接ssh的方法
2015/03/07 Python
深入解析Python的Tornado框架中内置的模板引擎
2016/07/11 Python
Python排序搜索基本算法之选择排序实例分析
2017/12/09 Python
Python使用os.listdir()和os.walk()获取文件路径与文件下所有目录的方法
2019/04/01 Python
django框架实现一次性上传多个文件功能示例【批量上传】
2019/06/19 Python
python计算波峰波谷值的方法(极值点)
2020/02/18 Python
使用python自动追踪你的快递(物流推送邮箱)
2020/03/17 Python
浅谈html5 video 移动端填坑记
2018/01/15 HTML / CSS
ASOS英国官网:英国在线时装和化妆品零售商
2017/05/19 全球购物
私有程序集与共享程序集有什么区别
2013/04/05 面试题
生日庆典策划方案
2014/06/02 职场文书
片区教研活动总结
2014/07/02 职场文书
不听老师话的万能检讨书
2014/10/04 职场文书
谢师宴邀请函
2015/02/02 职场文书
六一儿童节致辞
2015/07/31 职场文书
送给教师们,到底该如何写好教学反思?
2019/07/02 职场文书
Pytest中skip和skipif的具体使用方法
2021/06/30 Python