1.介绍一下vdom?

  1. virtual dom, 虚拟DOM
  2. 使用JS来模拟DOM结构
  3. DOM变化的对比,放在JS层来做(图灵完备语言),提高效率
  4. DOM操作非常昂贵(消耗性能)

2.Snabbdom的使用

  1. var snabbdom = window.snabbdom;
  2. // 定义patch
  3. var patch = snabbdom.init([
  4. snabbdom_class,
  5. snabbdom_props,
  6. snabbdom_style,
  7. snabbdom_eventlisteners
  8. ])
  9. // 定义h
  10. var h = snabbdom.h;
  11. var container = document.getElementById('container');
  12. // 生成vnode
  13. var vnode = h('ul#list', {}, [
  14. h('li.item', {}, 'Item 1'),
  15. h('li.item', {}, 'Item 2'),
  16. ]);
  17. patch(container, vnode)
  18. // 修改DOM内容
  19. document.getElementById('btn-change').addEventListener('click', function () {
  20. // 生成newVnode
  21. var newVnode = h('ul#list', {}, [
  22. h('li.item', {}, 'Item 1'),
  23. // DOM节点中不同的地方
  24. h('li.item', {}, 'Item B'),
  25. h('li.item', {}, 'Item 3'),
  26. ]);
  27. patch(vnode, newVnode)
  28. })

[!NOTE]

核心API总结:

  1. h('<标签名称>', { 属性 }, [子元素])
  2. h('<标签名>', {属性}, ‘...’)
  3. patch(container, vnode)
  4. patch(vnode, newNode)

3.介绍一下diff算法?

3.1 Diff算法是什么

  1. Linux中: diff 文件1.txt 文件2.txt
  2. Git中: git diff
  3. 在线比对工具

3.2 去繁就简

  1. diff算法实现非常复杂,实现难度很大,源码量很大
  2. 去繁就简,讲明白核心流程,不关心细节(非常高效的手段)
  3. 面试官也大部分不清楚细节,但是很关系核心流程的实现

3.3 VDOM为何使用diff算法?

  1. DOM操作是昂贵的,因此要尽量减少DOM的操作
  2. 找出本次DOM必须更新的节点来更新,其他的不更新
  3. 这个找出的过程,就需要使用diff算法(找出两个虚拟DOM的差异)

【前端知识体系-JS相关】虚拟DOM和Diff算法的更多相关文章

  1. 【前端知识体系-JS相关】组件化和React

    1. 说一下使用jQuery和使用框架的区别? 数据和视图的分离,(jQuery数据和视图混在一起,代码耦合)-------开放封闭原则 以数据驱动视图(只关注数据变化,DOM操作被封装) 2.说一下 ...

  2. 【前端知识体系-JS相关】深入理解MVVM和VUE

    1. v-bind和v-model的区别? v-bind用来绑定数据和属性以及表达式,缩写为':' v-model使用在表单中,实现双向数据绑定的,在表单元素外使用不起作用 2. Vue 中三要素的是 ...

  3. 【前端知识体系-JS相关】JS基础知识总结

    1 变量类型和计算 1.1 值类型和引用类型的区别? 值类型:每个变量都会存储各自的值.不会相互影响 引用类型:不同变量的指针执行了同一个对象(数组,对象,函数) 1.2 typeof可以及检测的数据 ...

  4. 【前端知识体系-JS相关】对移动端和Hybrid开发的理解?

    1.hybrid是什么,为何使用hybrid呢? 概念: hybrid就是前端和客户端的混合开发 需要前端开发人员和客户端开发人员配合完成 某些环节也可能会涉及到server端 大前端:网页.APP. ...

  5. 【前端知识体系-JS相关】JS-Web-API总结

    2.1 DOM操作 2.1.1 DOM的本质是什么? <!-- DOM树:二叉树 --> /* <?xml version="1.0" encoding=&quo ...

  6. 【前端知识体系-JS相关】深入理解JavaScript异步和单线程

    1. 为什么JavaScript是单线程? JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事.那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊. Jav ...

  7. 【前端知识体系-JS相关】ES6专题系列总结

    1.如何搭建ES6的webpack开发环境? 安装Node环境 node -v // 10.14.1 安装NPM环境 npm -v // 6.4.1 安装babel npm install @babe ...

  8. 【前端知识体系-JS相关】10分钟搞定JavaScript正则表达式高频考点

    1.正则表达式基础 1.1 创建正则表达式 1.1.1 使用一个正则表达式字面量 const regex = /^[a-zA-Z]+[0-9]*\W?_$/gi; 1.1.2 调用RegExp对象的构 ...

  9. 【前端知识体系-JS相关】你真的了解JavaScript编译解析的流程吗?

    1. JS编译解析的流程 1.1 JS运行分三步 语法分析(通篇扫描是否有语法错误),预编译(发生在函数执行的前一刻),解释执行(一行行执行). 1.2 预编译执行分五步 创建AO对象(Activat ...

随机推荐

  1. 02-Git远程仓库Github

    1.Git远程仓库 (Gitgub网站作为远程代码仓库时的操作和本地代码仓库一样的,只是仓库位置不同而已) 需要准备的东西: 1.准备Git源代码仓库https://github.com/ 2.准备李 ...

  2. 黄聪:php一句代码让http跳转https

    //其他框架请加到入口某共公加载的文件中 //方法一 https状态 if(!isset($_SERVER['HTTPS']) || $_SERVER['HTTPS'] == 'off'){ Head ...

  3. bootstrap 自定义模态窗口

    $(".classname").click(function () { $('#mymodel').modal('show'); alert('模态框打开了'); }); $('# ...

  4. GCD的Queue-Specific

    为了能够判断当前queue是否是之前创建的queue, 我们可以利用dispatch_queue_set_specific和dispatch_get_specific给queue关联一个context ...

  5. [PHP] 近期接手現有的企邮前端框架业务所遇困难

    1.邮箱前端有三大产品线,包括免费邮箱,VIP邮箱,企业邮箱,使用的一套代码,在代码中进行的逻辑判断处理,根据不同的配置进行不同的业务操作.有很多逻辑是各产品线是不同的,需要仔细开发和判断才能不会影响 ...

  6. 动态链接库(Dynamic Link Library)

    DLL INTRODUCTION A DLL is a library that contains code and data that can be used by more than one pr ...

  7. LVM 在线扩容磁盘(ubuntu 14.04 server)

    mware workstation 8 或者 vmware vsphere client 6.0( exsi 6.0) (前提:你的服务器需要有已经存在的卷组,才可以添加新的物理卷到卷组,然后再扩容逻 ...

  8. Shell命令-系统信息及显示之df、top

    文件及内容处理 - df.top 1. df:报告文件系统磁盘空间的使用情况 df命令的功能说明 df 命令用于显示目前在Linux系统上的文件系统的磁盘使用情况统计. df命令的语法格式 df [O ...

  9. C学习笔记(3)---作用域,数组, (少量指针入门)

    1. 作用域(scope):任何一种编程中,作用域是程序中定义的变量所存在的区域,超过该区域变量就不能被访问.C 语言中有三个地方可以声明变量. a. 在函数或块内部的局部变量 - 在某个函数或块的内 ...

  10. 【微学堂】线上Linux服务器运维安全策略经验分享

      技术转载:https://mp.weixin.qq.com/s?__biz=MjM5NTU2MTQwNA==&mid=402022683&idx=1&sn=6d403ab4 ...