VUE源码解析-Diff&虚拟DOM

本文深入探讨虚拟DOM库snabbdom,介绍如何搭建测试环境,理解并手写h函数以创建虚拟节点,解析虚拟节点属性。接着,详细阐述Diff算法原理,并动手实现新旧节点的比较。通过手写patch函数和处理不同情况的文本节点,读者将全面掌握虚拟DOM的更新机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

手写源码地址

snabbdom

snabbdom是著名的虚拟DOM库,是diff算法的鼻祖,Vue源码借鉴了snabbdom

测试环境搭建

  1. 搭建webpack和webpack-dev-server开发环境
  2. 需按照最新版webpack@5:npm i -D webpack@5 webpack-cli@3 webpack-dev-server@3
  3. 配置webpack.config.js文件
const path = require('path');
module.exports = {
    //入口
    entry: './src/index.js',
    //出口
    output: {
        publicPath: 'virtual',
        filename: 'bundle.js'
    },
    devServer: {
        port: 8080,
        contentBase: 'www'
    }
}

虚拟dom

用JavaScript对象描述dom的层次结构,dom中一切属性都在虚拟dom中有对应属性
在这里插入图片描述

新虚拟dom和老虚拟dom进行diff(精细化比较),算出应该如何最小量更新,最后反映到真正的dom上
在这里插入图片描述

snabbdom的h函数

  1. 作用:h函数用来产生虚拟节点(vnode)
    在这里插入图片描述

  2. 虚拟节点属性

    • children:子元素,默认undefined
    • data:属性、样式,默认{}
    • elm:对应的真实dom是否上树
    • key:唯一标识
    • sel:选择器
    • text:文本
  3. 创建虚拟节点

var myVNode = h('a', {
    props: {
        href: 'http://www.baidu.com',
        target: '_blank'
    }
}, 'hello world');
//嵌套使用
var myMultiVNode = h('ul',{},[
    h('li',{},'1'),
    h('li',{},'2'),
    h('li',{},'3')
])

手写h函数

  1. 根据源码的TS版代码,仿写JS代码
  2. 编写低配版h函数,接收三个参数,调用形态可以如下:
    • h(‘sel’,{},‘text’)
    • h(‘sel’,{},[])
    • h(‘sel’,{},h())

diff算法原理

在这里插入图片描述

手写diff算法

  1. 手写patch函数
    • 新旧节点不同时,删除旧的,调用createElement创建新的
    • 新旧节点相同时,精细化比较
      1. 手写新旧节点text的不同情况
      2. diff更新子节点
  2. 手写createElement函数
    在这里插入图片描述
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值