Vue 原理解析(四): 虚拟Dom是怎么生成的

虚拟Dom, 顾明思议并不是真实的Dom, 而是使用javascript 的对象来对真实dom的一个描述。 一个真实的dom 也无非是有标签名, 属性, 子节点等这些来描述它,demo如下:

真实Dom

<div id="app">
  <span>Vue!</span>
</div>

虚拟dom

{
  tag: 'div',
  attr:{
     id:'app'
  },
  children: [
    {
      tag: 'span',
      children: [
        {
          text: Vue!
        }
      ]
    }
  ],
}

我们可以在Render 函数里这样描述它:

new Vue({
  render(h) {
    return h('div', {
      attrs: {
        id: 'app',
      }
    }, [
      h('span', { children: [
        {
          text: Vue!
        } 
      ]} )
    ]
   )    
  }
})

开始挂载阶段

this._init() 方法的最后:

... 初始化

if (vm.$options.el) {    // 开始挂载
  vm.$mount(vm.$options.el)
}

参考链接 https://blog.csdn.net/chenzhizhuo/article/details/101205637

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值