VNode简介

VNode说明&作用
VNode是什么

VNode是JavaScript对象。VNode表示Virtual DOM,用JavaScript对象来描述真实的DOMDOM标签,属性,内容都变成对象的属性。就像使用JavaScript对象对一种动物进行说明一样{name: 'Hello Kitty', age: 1, children: null}

VNode的作用

通过rendertemplate模版描述成VNode,然后进行一系列操作之后形成真实的DOM进行挂载。

VNode的优点
  1. 兼容性强,不受执行环境的影响。VNode因为是JS对象,不管Node还是浏览器,都可以统一操作,从而获得了服务端渲染、原生渲染、手写渲染函数等能力。
  2. 减少操作DOM,任何页面的变化,都只使用VNode进行操作对比,只需要在最后一步挂载更新DOM,不需要频繁操作DOM,从而提高页面性能。
VNode如何生成

Vue源码中,VNode是通过一个构造函数生成的。

export default class VNode {
  constructor (
    tag?: string,
    data?: VNodeData,
    children?: ?Array<VNode>,
    text?: string,
    elm?: Node,
    context?: Component,
    componentOptions?: VNodeComponentOptions,
    asyncFactory?: Function
  ) {
    this.tag = tag
    this.data = data
    this.children = children
    this.text = text
    this.elm = elm
    this.ns = undefined
    this.context = context
    this.fnContext = undefined
    this.fnOptions = undefined
    this.fnScopeId = undefined
    this.key = data && data.key
    this.componentOptions = componentOptions
    this.componentInstance = undefined
    this.parent = undefined
    this.raw = false
    this.isStatic = false
    this.isRootInsert = true
    this.isComment = false
    this.isCloned = false
    this.isOnce = false
    this.asyncFactory = asyncFactory
    this.asyncMeta = undefined
    this.isAsyncPlaceholder = false
  }
}

VNode构造函数看起来十分简单,先走一遍VNode的生成过程。

// 模版
<a class="demo" style="color: red" href="#">
    generator VNode
</a>
// VNode描述
{
  tag: 'a',
  data: {
    calss: 'demo',
    attrs: {
      href: '#'
    },
    style: {
      color: 'red'
    }
  },
  children: ['generator VNode']
}

这个JS对象,已经囊括了整个模板的所有信息,完全可以根据这个对象来构造真实DOM

VNode存放哪些信息
  1. data:存储节点的属性,绑定的事件等
  2. elm:真实DOM 节点
  3. context:渲染这个模板的上下文对象
  4. isStatic:是否是静态节点
VNode存放

在初始化完选项,解析完模板之后,就需要挂载DOM了。此时就需要生成VNode,才能根据 VNode生成DOM然后挂载。创建出来的VNode需要被存起来,主要存放在三个位置:parent_vnode$vnode

  • 6
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue的canvas vnodeVue框架中用于创建和管理canvas元素的虚拟节点。 虚拟节点(vnode)是Vue中抽象出来的一种数据结构,用于描述DOM元素。通过使用虚拟节点,Vue可以跟踪每个组件的状态变化,并在需要时更新DOM。在Vue中,每个canvas元素都会被表示为一个独立的vnode。 canvas vnode提供了一种将Vue和canvas元素相结合的灵活方式。通过创建canvas vnode,我们可以在Vue组件中使用canvas元素,并利用Vue的数据驱动特性来动态更新canvas的内容。 在使用canvas vnode时,我们可以通过Vue的模板语法或者render函数来创建vnode。然后,我们可以将这些vnode添加到Vue组件的模板中。一旦vnode被添加到模板中,Vue会将其转换为真实的DOM元素,并将其插入到页面中。 一旦canvas vnode被渲染到页面中,我们可以使用canvas的API操作它。这些API包括绘制线条、绘制图形、绘制文本等功能。我们可以通过监听Vue组件的数据变化,来实现动态更新canvas的内容。当数据发生变化时,Vue会自动重新渲染vnode,并更新canvas的内容。 使用canvas vnode,我们可以利用Vue的响应式系统来管理canvas元素的状态。当事件发生或数据变化时,我们可以通过更新VNode的数据来实现动态的canvas绘制。同时,由于canvas vnode会被Vue管理,我们可以利用Vue的生命周期钩子函数来控制canvas的绘制时机,以提高应用的性能和用户体验。 总之,Vue的canvas vnode为我们提供了一种简单、灵活的方式来操作canvas元素,并将其和Vue的数据驱动特性相结合。通过使用canvas vnode,我们可以实现动态的、响应式的canvas绘制,提高应用的可维护性和交互性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值