vnode
获取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的更多相关文章
- vue源码学习-vnode的挂载和更新流程
概述 本文主要介绍在视图的渲染过程中,Vue 是如何把 vnode 解析并挂载到页面中的.我们通过一个最简单的例子来分析主要流程: <div id="app"> {{s ...
- Vue源码终笔-VNode更新与diff算法初探
写完这个就差不多了,准备干新项目了. 确实挺不擅长写东西,感觉都是罗列代码写点注释的感觉,这篇就简单阐述一下数据变动时DOM是如何更新的,主要讲解下其中的diff算法. 先来个正常的html模板: & ...
- 说说VNode节点(Vue.js实现)
写在前面 因为对Vue.js很感兴趣,而且平时工作的技术栈也是Vue.js,这几个月花了些时间研究学习了一下Vue.js源码,并做了总结与输出.文章的原地址:https://github.com/an ...
- Vue源码之 diff Vnode
其实现在这个还没看懂,只能是初步看一下 _update调用__patch__方法,如果prevVnode(也就是oldVnode),旧vnode和新vnode对比,如果没有,就vnode就是vm.$e ...
- Vue 中是如何解析 template 字符串为 VNode 的?
在接触 React 时候,我只了解到通过 babel 可以把 JSX 转成 VNode(通过调用 React.createElement 方法),但是对其具体是如何转换的却不了解. 很明显,回答失败. ...
- vue VNode如何使用,是什么东西?
前言:element ui 中有些 demo 使用了 vue 的 VNode,但是 demo 毕竟不全,所以想要了解 VNode 到底是什么,如何写出符合自己业务的代码. vue 官网介绍:渲染函数 ...
- vue虚拟DOM源码学习-vnode的挂载和更新流程
代码如下: <div id="app"> {{someVar}} </div> <script type="text/javascript& ...
- vnode的挂载和更新流程 -- 简介.
来源 vnode原理 diff图解 <div id="app"> {{someVar}} </div> <script type="text ...
- 进程表/文件表/inode/vnode
一般我们讲,都说进程有文件描述符表,文件描述符表中的指针指向某个inode,这中间省略了file,dentry对象,对准确理解VFS结构无益,本文结合网络所查,并根据APUE8.3和LKD13.11章 ...
- vue自定义指令VNode详解(转)
1.自定义指令钩子函数 Vue.directive('my-directive', {bind: function () {// 做绑定的准备工作// 比如添加事件监听器,或是其他只需要执行一次的复杂 ...
随机推荐
- Go语言实现:【剑指offer】从尾到头打印链表
该题目来源于牛客网<剑指offer>专题. 输入一个链表,按链表从尾到头的顺序返回一个ArrayList. Go语言实现: type ListNode struct { Val int ...
- postman之下载文件
前言 小伙伴们在实际的测试工作中是否遇到过下载的接口呢,例如网盘的项目就涉及到上传和下载的接口了,那么我们如何利用postman对下载接口进行测试呢?下面我们一起来学习吧! 练习案例:下载接口:htt ...
- ArtiPub:一款开源的一文多发平台
文章来自我的博客:https://blog.ljyngup.com/archives/705.html/ 看到感觉挺有意思的,有空找个空闲的VPS搭建一下. 转自官方Github仓库 ArtiPub ...
- 《Head first设计模式》之模版方法模式
模板方法模式在一个方法中定义了一个算法的骨架,而将一些步骤延迟到子类中.模板方法使得子类可以在不改变算法结构的情况下,重新定义算法中的某些步骤. 有些人没有咖啡就活不下去:有些人则离不开茶.两者共同的 ...
- 地址ip丢失
好好的机器 ip地址没有了,好几台机器出现这个情况,目前判断是 NetworkManager 的问题: 先了解一下network和NetworkManager之间的区别,还有他们分别代表了什么. ...
- iptbales 允许访问vsftp
1.允许20 21 端口iptables -I INPUT -p tcp -m multiport --dport 20,21 -j ACCEPT 2.允许关联包通过iptables -A INPUT ...
- nrm安装与配置(nrm管理npm源)
1.nrm nrm(npm registry manager )是npm的镜像源管理工具,有时候国外资源太慢,使用这个就可以快速地在 npm 源间切换 2.安装nrm 在命令行执行命令,npm ins ...
- 珠峰-buffer-流事件
#### Buffer // 字符串的二进制转10进制 let r = parseInt('11111111', 2); console.log(r); // 打印 255 // Number类型转为 ...
- C++ 解决列车重排问题
问题节选自<<数据结构.算法与应用(C++语言描述)>>, 思路与代码为原创, 如有疏漏及问题欢迎指正 问题描述: 一辆列车有n节车厢, 车厢排列乱序(如: 284657139 ...
- DOTNET Core MVC (一)
以控台的形式,运行.net core mvc 代码, Host.CreateDefaultBuilder(args) .ConfigureWebHostDefaults(webBuilder => ...