当前位置: 首页 > news >正文

Vue之transition组件

Vue提供了transition组件,使用户可以更便捷地添加过渡动画效果。

transition组件

transition组件也是一个抽象组件,并不会渲染出真实dom。Vue会在其第一个真实子元素上添加过渡效果。

props

 

 

render

这里将render分为两部分,第一部分界定真正添加过渡效果的子节点。

第一部分

首先获取transition的子元素(通过默认插槽$slots.default),子节点需要有以下特征:

1. 子元素存在且非文本节点

2. 只存在单个子元素,否则会控制台提示用transition-group

3.hasParentTransition的目的是在transition组件是所在父组件的根节点,且父组件外部也有transition组件,即父组件也被添加了过渡效果的情况下,防止重复添加过渡效果。这里需要对parent有了解。

在vue.prototype._render函数执行的时候会给render函数渲染返回的_vnode设置parent(就是占位符vnode)。那么,只有当在当前组件中transition组件为根组件时,transition组件的$vnode才有parent属性;且当前组件的占位符节点也具有transition属性,即,当前组件的占位符节点外面也包裹了transition属性。这就说明重复添加了过渡效果,只需要执行最外层的过渡效果即可。

4. getRealChild,避免子元素也是抽象组件,需要获取真实子元素。

 

 

 

 

第二部分

1. 定义id及真实子节点的key

2. extractTransitionData将transition组件绑定的属性及时间给真实子节点

3. 通过transition组件的_vnode属性获取组件的根节点,定义为oldChild,更新oldChild属性

4. 根据mode类别做相应动作。

 

 

 

 

mode

这里将mode单独拎出来说明一下。

  • in-out:新元素先进行过渡,完成之后当前元素过渡离开。

  • out-in:当前元素先进行过渡,完成之后新元素过渡进入。

官方说过渡模式的出现是为了弥补多个元素动画之间不协调。例如进入/离开效果同时出现:cn.vuejs.org/v2/guide/tr…

其实现原理就是在data.hook属性中添加了很多hook,使得可以控制特效动画执行顺序。

最后

其实transition组件也不难,主要是各种前提条件判断的。

最绕的一点还是做边界检测,如何做到防止重复添加过渡效果

在整体分析下来,似乎并没有发现transition组件是如何控制过渡动画的,也不知道用户定义的钩子函数及各种属性如何读取及调用。

http://www.lryc.cn/news/178476.html

相关文章:

  • lenovo联想笔记本电脑ThinkPad X13 AMD Gen2(20XH,20XJ)原装出厂Windows10系统镜像
  • php导出cvs,excel打开数字超过16变科学计数法
  • CSS 模糊效果 CSS 黑白效果 CSS调整亮度 对比度 饱和度 模糊效果 黑白效果反转颜色
  • 蓝桥杯 题库 简单 每日十题 day11
  • dart flutter json 转 model 常用库对比 json_serializable json_model JsonToDart
  • nginx启用了自动目录列表功能的安全漏洞修复方法
  • vector向量类使用
  • 【Java 进阶篇】MySQL多表查询:内连接详解
  • C理解(四):链表
  • 新手教程,蛋糕小程序的搭建流程一网打尽
  • springcloud之自我介绍
  • 机器学习之神经网络的层次
  • 力扣每日一题(+日常水几道题)
  • 百度SEO不稳定的原因及解决方法(百度SEO不稳定因素的5大包括)
  • 深度学习(1)---卷积神经网络
  • 探索社会工程的深度:从定义到高级攻击策略
  • CTF 入门指南:从零开始学习网络安全竞赛
  • Spring整合第三方框架
  • Linux Shell 无vi获取文件某行指定内容和修改某行指定内容
  • 在EXCEL中构建加载项之创建加载项的目的及规范要求
  • Hive【Hive(三)查询语句】
  • 商场做小程序商城的作用是什么?
  • XPD738协议系列-USB Type-C PD 和 Type-A 双口控制器
  • 【面试八股】IP协议八股
  • 【冰糖R语言】创建R包(打包R程序)
  • 照片后期处理软件DxO FilmPack 6 mac中文说明
  • 51单片机音乐闹钟秒表倒计时整点报时多功能电子钟万年历数码管显示( proteus仿真+程序+原理图+报告+讲解视频)
  • Scala第九章节
  • arduino - UNO-R3,mega2560-R3,NUCLEO-H723ZG的arduino引脚定义区别
  • 提取多个txt数据并合成excel——例子:与中国建交的国家