获取vnode对象

  • vm.$slots对象下的所有值
  • vm.$scopedSlots对象的值返回一个函数,该函数执行后返回vnode对象
  • directives自定义指令中钩子函数的参数3和参数4,例如钩子函数bind:bind: function (el, binding, vnode, oldVnode) { ... )
  • render渲染函数的参数1是一个返回vnode的函数,例如这里的参数h:render: function (h) { ... }
  • 函数式组件context.children返回一个vnode数组
  • 函数式组件context.slots返回一个函数,该函数运行后返回一个vnode组成的对象

————————————————————————————————————————————————————

vnode构造函数传参

tag?: string,

data?: VNodeData,

children?: ?Array,

text?: string,

elm?: Node,

context?: Component,

  • 函数式组件和普通组件中该值不同

componentOptions?: VNodeComponentOptions,

asyncFactory?: Function

————————————————————————————————————————————————————

vnode对象的属性

this.tag = tag

this.data = data

  • 包含以下

    • attrs
    • class:通过v-bind绑定在组件上的class,格式和v-bind相同
    • staticClass:通过字符串绑定在组件上的class
    • hook
    • model
    • on
    • props
    • staticStyle:原生样式对象,通过v-bind绑定到style上的这里也会体现
    • style:通过v-bind绑定到组件上的对象

this.children = children

  • 当表单项插入el-form时,该值为undefined

this.text = text

this.elm = elm

this.ns = undefined

this.context = context

  • rendered in this component's scope(在此组件的范围内呈现)

this.fnContext = undefined

  • real context vm for functional nodes(功能节点的实上下文虚拟机)

this.fnOptions = undefined

  • for SSR caching(用于SSR缓存)

this.fnScopeId = undefined

  • functional scope id support(功能范围ID支持)

this.key = data && data.key

this.componentOptions = componentOptions

this.componentInstance = undefined

  • component instance(组件实例)

this.parent = undefined

  • component placeholder node(组件占位符节点)

this.raw = false

  • contains raw HTML? (server only)(包含原始HTML)

this.isStatic = false

  • hoisted static node(吊装静节点)

this.isRootInsert = true

  • necessary for enter transition check(输入转换检查所必需的)

this.isComment = false

  • empty comment placeholder?(空注释占位符)

this.isCloned = false

  • is a cloned node?(是克隆的节点)

this.isOnce = false

  • is a v-once node?

this.asyncFactory = asyncFactory

  • async component factory function(异步组件工厂函数)

this.asyncMeta = undefined

this.isAsyncPlaceholder = false

vnode的更多相关文章

  1. vue源码学习-vnode的挂载和更新流程

    概述 本文主要介绍在视图的渲染过程中,Vue 是如何把 vnode 解析并挂载到页面中的.我们通过一个最简单的例子来分析主要流程: <div id="app"> {{s ...

  2. Vue源码终笔-VNode更新与diff算法初探

    写完这个就差不多了,准备干新项目了. 确实挺不擅长写东西,感觉都是罗列代码写点注释的感觉,这篇就简单阐述一下数据变动时DOM是如何更新的,主要讲解下其中的diff算法. 先来个正常的html模板: & ...

  3. 说说VNode节点(Vue.js实现)

    写在前面 因为对Vue.js很感兴趣,而且平时工作的技术栈也是Vue.js,这几个月花了些时间研究学习了一下Vue.js源码,并做了总结与输出.文章的原地址:https://github.com/an ...

  4. Vue源码之 diff Vnode

    其实现在这个还没看懂,只能是初步看一下 _update调用__patch__方法,如果prevVnode(也就是oldVnode),旧vnode和新vnode对比,如果没有,就vnode就是vm.$e ...

  5. Vue 中是如何解析 template 字符串为 VNode 的?

    在接触 React 时候,我只了解到通过 babel 可以把 JSX 转成 VNode(通过调用 React.createElement 方法),但是对其具体是如何转换的却不了解. 很明显,回答失败. ...

  6. vue VNode如何使用,是什么东西?

    前言:element ui 中有些 demo 使用了 vue 的 VNode,但是 demo 毕竟不全,所以想要了解 VNode 到底是什么,如何写出符合自己业务的代码. vue 官网介绍:渲染函数 ...

  7. vue虚拟DOM源码学习-vnode的挂载和更新流程

    代码如下: <div id="app"> {{someVar}} </div> <script type="text/javascript& ...

  8. vnode的挂载和更新流程 -- 简介.

    来源 vnode原理 diff图解 <div id="app"> {{someVar}} </div> <script type="text ...

  9. 进程表/文件表/inode/vnode

    一般我们讲,都说进程有文件描述符表,文件描述符表中的指针指向某个inode,这中间省略了file,dentry对象,对准确理解VFS结构无益,本文结合网络所查,并根据APUE8.3和LKD13.11章 ...

  10. vue自定义指令VNode详解(转)

    1.自定义指令钩子函数 Vue.directive('my-directive', {bind: function () {// 做绑定的准备工作// 比如添加事件监听器,或是其他只需要执行一次的复杂 ...

随机推荐

  1. Chrome恢复显示网址 https:// 和 www

    文章来自我的博客: https://blog.ljyngup.com/archives/686.html/ Chrome这个新规弄得我也很蛋疼,每次一点输入框就突然突出来一下.后来在Hostloc论坛 ...

  2. pytorch之 CNN

    # library # standard library import os # third-party library import torch import torch.nn as nn impo ...

  3. pytorch之 activation funcion

    import torch import torch.nn.functional as F from torch.autograd import Variable import matplotlib.p ...

  4. STM32F4相关

    常用术语 AHB与APB的地位相当于PC中的南北桥,是两道独立的片内总线.AHB:advanced high-performance bus:APB: advanced peripherals bus

  5. numpy 介绍与使用

    一.介绍 中文文档:https://www.numpy.org.cn/ NumPy是Python语言的一个扩展包.支持多维数组与矩阵运算,此外也针对数组运算提供大量的数学函数库.NumPy提供了与Ma ...

  6. xmppmini 项目详解:一步一步从原理跟我学实用 xmpp 技术开发 2.登录的实现

    第二章登录的实现 金庸<倚天屠龙记> 张三丰缓缓摇头,说道:“少林派累积千年,方得达成这等绝技,决非一蹴而至,就算是绝顶聪明之人,也无法自创.”他顿了一顿,又道:“我当年在少林寺中住过,只 ...

  7. MySql数据库精简与绿色启动

    1.下载MYSQL的zip包,解压ZIP包 版本低的相对需要的空间少,最好能在mysql-5.6以下,我测试的最高5.6版本为mysql-5.6.46,主要是里面有my.ini文件,高于5.6的版本里 ...

  8. nginx 修改上传文件的大小限制

    nginx默认的上传文件大小是有限制的,一般为2MB,如果你要上传的文件超出了这个值,将可能上传失败.修改的地方有: 1. php.ini: upload_max_filesize = 8M   2. ...

  9. Linux的crontab 命令

    crontab 命令 简介 从输入设备读取指令,并将其存放于 crontab 文件中,以供之后读取和执行,即:crontab 是 Linux 系统中添加计划任务,定时执行一些必要的脚本所必不可少的工具 ...

  10. windows系统中如何删除文件路径过长的文件

    Q:通常在使用npm安装包后,路径会变的非常的长,有时候无法手动删除文件: 这个时候可以选中文件点击>添加文件到压缩文件,在弹出出来的框中勾选 压缩后删除原文件,>最后删除压缩包