最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 从零手写简易Vue3(四)—— Virtual Dom

    正文概述 掘金(Elecat)   2020-12-15   523
    • createApp() & mount()
    • setup()
    • render() h()
    • Virtual Dom
    • 生命周期hooks
    • Proxy代理
    • reactive() ref()
    • computed()
    • watch()
    • provide() inject()
    • directives()
    • components()

    什么是Virtual Dom?

    英文全称Virtual Document Object Model,直译:虚拟的文档对象模型。

    简而言之,就是使用js 对象去描述一个dom节点,有很多相关的文章描述,这里不再赘述。

    我们可以像这样理解一个Virtual Dom

    <div id="app">my vdom</div>
    
    const vdom = {
      tag:'div',
      text:'my vdom',
      attributes:{
        id:'app'
      },
      children:[]
    }
    

    而在vue中,有一种自己独特的Virtual Dom——VNode,在Virtual Dom的思想基础上,添加了一些vue运行编译所需要的属性,一个初始VNode模板在源码中是这样定义的:

    // packages/runtime-core/src/vnode.ts
    const vnode: VNode = {
        __v_isVNode: true, // 区分VNode与普通js object的标志
        [ReactiveFlags.SKIP]: true,
        type,
        props,
        key: props && normalizeKey(props),
        ref: props && normalizeRef(props),
        scopeId: currentScopeId,
        children: null,
        component: null,
        suspense: null,
        ssContent: null,
        ssFallback: null,
        dirs: null,
        transition: null,
        el: null,
        anchor: null,
        target: null,
        targetAnchor: null,
        staticCount: 0,
        shapeFlag,
        patchFlag,
        dynamicProps,
        dynamicChildren: null,
        appContext: null
    }
    

    为什么要使用Virtual Dom?

    一个面试的常见问题:请谈谈你对虚拟dom的理解

    初级回答

    操作虚拟dom比操作真实dom元素性能好。

    进阶版

    将dom元素抽象为js对象,结合dom diff算法在更新视图时起到性能优化的效果。

    高级版

    1.将页面元素抽象为对象,不再局限于浏览器的Dom,奠定了跨平台渲染的基础,打开了函数式UI编程的大门。

    2.浏览器不会对Dom操作进行缓存 => 批量处理。意味着你操作了Dom多少次,浏览器就会渲染多少次。而引入了Virtual Dom的概念后,我们可以将多次Dom更新都先体现在Virtual Dom上,再统一映射到真实Dom节点,避免掉了一部分重复渲染工作。

    *注:由于兼容性原因,MutationObserver的方式已被废弃

    3.不仅如此,在将VNode转化为Dom元素时还采用了优化后的diff算法:不再递归遍历整颗树,而是采用深度优先的方式逐层比较同级的树节点;还可以为Dom元素设置key值,加强节点的可复用性。

    由此可见,Virtula Dom的理想使用场景是:

    • Dom结构繁杂
    • 需要频繁的操作Dom
    • 多端渲染

    反过来,这些情况下则不适用Virtual Dom

    • Dom结构简单
    • 几乎不需要对Dom进行修改

    在页面的首次渲染中,相较于Dom.innerHTMLVirtual Dom多了一步转化VNode的过程,速度有可能会慢于Dom.innerHTML;而在后续的Dom更新过程中,每次都要执行diff计算,而且内存中要始终维护一份树结构的备份。

    所以要仔细斟酌,使用Virtual Dom所带来的提升是否能cover住所牺牲的部分。


    起源地下载网 » 从零手写简易Vue3(四)—— Virtual Dom

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元