Vue中的基础过渡动画及实现原理解析


Posted in Javascript onDecember 04, 2018

前言

在日常开发中 动画是必不可少的一部分 不仅能让元素直接的切换显得更加自然 同时也能极大的增强用户体验 因此 在Vue之中也提供了非常强大的关于动画这方面的支持 Vue不仅支持用CSS来写一些过渡效果 同时也是支持JS的 不过在这个文章中讲述的都是如何利用CSS来实现过渡动画、keyframes动画以及实现的原理

过渡动画实现的原理

1.首先最基础的一点在于 如果你想要在单元素/单个组件之中实现过渡动画 那么 你需要在元素/组件所在的HTML标签之外包裹一层  <transition>标签

2.当元素/组件被<transition>标签包裹了以后 那么Vue会自动的为我们构建一个动画流程 具体的流程会在下文提到 因此先记住这句话就行啦 也就是说 如果你在<style>标签中添加了一些样式的话Vue会自动的在某个时间节点给元素或者组件添加、删除对应的样式

3.上面提到了当元素/组件被<transition>标签包裹的时候Vue会自动的构建动画流程 也就是自动的在某个时间节点添加/删除对应的CSS类名 Vue其实提供了6个对应的类名 这里借助官网的一张图来罗列

Vue中的基础过渡动画及实现原理解析 

光这样看官网文字的解释可能感觉还不够清楚 所以这里我们借助一张图来帮助我们更好的理解这些CSS类名分别在什么时候被添加、移除

4 各个类名添加删除的时间

4.1

Vue中的基础过渡动画及实现原理解析 

我们假设黑色横线作为动画的整个流程 红点为动画开始的瞬间 那么 当我们用  <transition>标签包裹了元素/组件的时候 Vue会在动画即将开始还没开始的时候添加两个CSS类名 分别是v-enter/v-enter-to当动画开始的瞬间v-enter被自动的移除 而v-enter-active这个class会一直存在于整个动画过程中 直到动画结束的时候跟v-enter/v-enter-to一起被自动删除

4.2

Vue中的基础过渡动画及实现原理解析 

我们同样还是假设黑色横线作为动画的整个流程 那么在这里可以看到v-leave会在动画还没有开始的时候被添加上去 当动画开始的瞬间v-leave被移除 v-leave-to被添加 而v-leave-active会一直存在于整个动画过程中 直到动画结束的时候跟v-leave/v-leave-to一起被移除

###Coding

当有了这些理论知识以后 就可以动手写一个非常简单的demo了 假设现在有一个需求 页面上某个元素 通过按钮来控制隐藏和显示 同时这个隐藏和显示的过程中 有一个透明度由0-1的渐变过程

思路

通过v-if控制元素的显示 同时利用<transition>标签包裹元素实现透明度变化的过渡过程

1.先搭建基本页面以及通过按钮点击事件控制元素的隐藏与显示

Vue中的基础过渡动画及实现原理解析 

2.既然已知vue会在元素被<transition>包裹以后自动添加类名 那就在<style>标签里写上对应的样式效果

<style>
 .v-enter,
 .v-leave-to {
  opacity: 0;
 }
 .v-enter-active,
 .v-leave-active {
  transition: opacity 3s;
 }
 </style>

这里需要理解的一点在于 上文已经提到 当进场动画触发的时候 v-enter会立马被移除 因此在样式里把opacity写成0 也就是说 原本页面上没有显示但是即将要显示这个元素的时候 opacity会变为1 而v-enter-active全程都在监听transition:opacity的变化 如果变化了 就让效果在3秒内结束 反之退场动画也是同样的 v-leave-to会在动画执行的时候被添加 这个时候 v-leave-active感知到了transition:opacity的变化 会在3秒内做出对应的改变 最终代码运行结果如下

Vue中的基础过渡动画及实现原理解析

总结

以上所述是小编给大家介绍的Vue中的基础过渡动画及实现原理解析,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript中的其他对象
Jan 16 Javascript
为指定元素增加样式的js代码
Dec 09 Javascript
JQuery与iframe交互实现代码
Dec 24 Javascript
jQuery中:first选择器用法实例
Dec 30 Javascript
JS实现的鼠标跟随代码(卡通手型点击效果)
Oct 26 Javascript
js判断移动端是否安装某款app的多种方法
Dec 18 Javascript
Ext JS框架程序中阻止键盘触发回退或者刷新页面的代码分享
Jun 07 Javascript
js实现图片粘贴上传到服务器并展示的实例
Nov 08 Javascript
jQuery实现的简单拖拽功能示例【测试可用】
Aug 14 jQuery
vue中实现点击按钮滚动到页面对应位置的方法(使用c3平滑属性实现)
Dec 29 Javascript
微信小程序中的列表切换功能实例代码详解
Jun 09 Javascript
antd的select下拉框因为数据量太大造成卡顿的解决方式
Oct 31 Javascript
使用FormData实现上传多个文件
Dec 04 #Javascript
vue自定义指令的创建和使用方法实例分析
Dec 04 #Javascript
用vuex写了一个购物车H5页面的示例代码
Dec 04 #Javascript
vue实现的双向数据绑定操作示例
Dec 04 #Javascript
使用jquery模拟a标签的click事件无法实现跳转的解决
Dec 04 #jQuery
jQuery利用FormData上传文件实现批量上传
Dec 04 #jQuery
vue实现的组件兄弟间通信功能示例
Dec 04 #Javascript
You might like
vBulletin HACK----显示话题大小和打开新窗口于论坛索引页
2006/10/09 PHP
php实现将数组转换为XML的方法
2015/03/09 PHP
PHP基于文件存储实现缓存的方法
2015/07/20 PHP
部署PHP时的4个配置修改说明
2015/10/19 PHP
laravel清除视图缓存的代码
2019/10/23 PHP
javascript Onunload与Onbeforeunload使用小结
2009/12/31 Javascript
jquery多行滚动/向左或向上滚动/响应鼠标实现思路及代码
2013/01/23 Javascript
关于jquery中全局函数each使用介绍
2013/12/10 Javascript
jquery禁止输入数字以外的字符的示例(纯数字验证码)
2014/04/10 Javascript
关闭时刷新父窗口两种方法
2014/05/07 Javascript
js遍历子节点子元素附属性及方法
2014/08/19 Javascript
JavaScript实现N皇后问题算法谜题解答
2014/12/29 Javascript
javascript父子页面通讯实例详解
2015/07/17 Javascript
每天一篇javascript学习小结(Array数组)
2015/11/11 Javascript
详解JavaScript 中的 replace 方法
2016/01/01 Javascript
bootstrap3 兼容IE8浏览器!
2016/05/02 Javascript
微信小程序中使用ECharts 异步加载数据实现图表功能
2018/07/13 Javascript
判断js数据类型的函数实例详解
2019/05/23 Javascript
利用node.js开发cli的完整步骤
2020/12/29 Javascript
Python pickle模块用法实例
2015/04/14 Python
基于scrapy实现的简单蜘蛛采集程序
2015/04/17 Python
Python使用gensim计算文档相似性
2016/04/10 Python
Python生成任意范围任意精度的随机数方法
2018/04/09 Python
使用anaconda的pip安装第三方python包的操作步骤
2018/06/11 Python
python 非线性规划方式(scipy.optimize.minimize)
2020/02/11 Python
澳大利亚家具和家居用品在线商店:Interiors Online
2018/03/05 全球购物
ZWILLING双立人法国网上商店:德国刀具锅具厨具品牌
2019/08/28 全球购物
阿迪达斯香港官网:adidas香港
2019/11/09 全球购物
父亲生日宴会答谢词
2014/01/10 职场文书
十月份红领巾广播稿
2014/01/22 职场文书
2014年百日安全生产活动总结
2014/05/04 职场文书
承诺书范本
2015/01/21 职场文书
升学宴来宾致辞
2015/07/27 职场文书
HTML页面滚动时部分内容位置固定不滚动的实现
2021/04/14 HTML / CSS
python基础之类方法和静态方法
2021/10/24 Python
关于MySQL中的 like操作符详情
2021/11/17 MySQL