vue.3.0 dom赋值_尤大大教你Vue3.0虚拟Dom快速入门【实践】

923a22a3040e0635dc25fffb5d1bfbe4.png

作者:蜗牛老湿

转发链接:https://juejin.im/post/5e9faa8fe51d4546fe263eda

整体尤大直播的过程,劝退大兄弟已经总结的贼棒了 ,请访问:

《聊聊昨晚尤雨溪现场针对Vue3.0 Beta版本新特性知识点汇总》

Vue3核心的Typescript,Proxy响应式,Composition解决代码反复横跳都有很棒的文章剖析了, 我总结一下虚拟Dom部分把,并对比一下React, vdom的重写也是vue3性能如此优秀的重要原因

  1. 《Vue真是太好了 壹万多字的Vue知识点 超详细!》
  2. 《Vue 3.0 Beta 和React 开发者分别杠上了》
001d263bc10384319014271fb5b3296f.png

Vue3.0的虚拟dom

先说结论,静态标记,upadte性能提升1.3~2倍,ssr提升2~3倍,怎么做到的呢

10767e01b30a19736e6ba527c2e0dd8b.png
2645d781e7f32607341ecaa31beee2b2.png

编译模板的静态标记

我们来看一段很常见的代码

技术摸鱼

今天天气真不错

{ {name}}
复制代码

vue2中会解析

function render() {  with(this) {    return _c('div', {      attrs: {        "id": "app"      }    }, [_c('h1', [_v("技术摸鱼")]), _c('p', [_v("今天天气真不错")]), _c('div', [_v(      _s(name))])])  }}复制代码

其中前面两个标签是完全静态的,后续的渲染中不会产生任何变化,Vue2中依然使用_c新建成vdom,在diff的时候需要对比,有一些额外的性能损耗

我们看下vue3中的解析结果

import { createVNode as _createVNode, toDisplayString as _toDisplayString, openBlock as _openBlock, createBlock as _createBlock } from "vue"export function render(_ctx, _cache) {  return (_openBlock(), _createBlock("div", { id: "app" }, [    _createVNode("h1", null, "技术摸鱼"),
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值