简单谈谈vue的过渡动画(推荐)


Posted in Javascript onOctober 11, 2017

在vue中,实现过渡动画一般是下面这样:

<transition name="fade">
 <div></div>
</transition>

用一个transition对元素或者组件进行封装.

在过渡的时候,会有 4 个(CSS)类名在 enter/leave 的过渡中切换。

1.v-enter: 定义进入过渡的开始状态。在元素被插入时生效,在下一个帧移除。

2.v-enter-active: 定义进入过渡的结束状态。在元素被插入时生效,在 transition/animation 完成之后移除。

3.v-leave: 定义离开过渡的开始状态。在离开过渡被触发时生效,在下一个帧移除。

4.v-leave-active: 定义离开过渡的结束状态。在离开过渡被触发时生效,在 transition/animation 完成之后移除。

上面是官方文档的原话,但是这4个类名如何运用呢?下面看个例子

<transition name="fold">
 <div v-show="show" class="example"></div>
</transition>

css:
.example {
 width: 100px;
 height: 100px;
 transform: translate3d(0, -100px, 0);
}
.fold-enter-active, .fold-leave-active {
 transition: all .5s;
}
.fold-enter, .fold-leave-active {
 transform: translate3d(0, 0, 0);
}

当show = true时:

这里的fold-enter,是在元素显示的一瞬间被加入,然后瞬间被移除,在上面的例子中,example这个块状元素本来因为有了transform: translate3d(0, -100px, 0)这个样式,所以被上移了100px,但是因为fold-enter,所以将example这个块状元素移到了原位,但是fold-enter因为瞬间就被移除掉了,所以这时候的元素的样式又变成了transform: translate3d(0, -100px, 0),但是这时候fold-enter-active这个样式就生效了,因为设置了transition: all .5s,所以元素会在0.5s的时间内上移100px,在过渡动画结束之后,fold-enter-active这个类马上被移除.

当show = false时:

example不会马上消失,这个时候fold-leave-active这个类就起作用了,example这时的位置是在-100px,fold-leave-active定义的是过渡的结束状态:transform: translate3d(0, 0, 0);,但是同时又设置了transition: all .5s,所以这时元素会在0.5s的时间内下移100px.之后fold-leave-active被移除.

官网的一张图

简单谈谈vue的过渡动画(推荐)

另外,还可以在动画中调用js钩子函数:

<transition
 v-on:before-enter="beforeEnter"
 v-on:enter="enter"
 v-on:after-enter="afterEnter"
 v-on:enter-cancelled="enterCancelled"
 v-on:before-leave="beforeLeave"
 v-on:leave="leave"
 v-on:after-leave="afterLeave"
 v-on:leave-cancelled="leaveCancelled"
>
</transition>

不过用的不多,可以在methods中定义这些方法.

以上这篇简单谈谈vue的过渡动画(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery取消选择select下拉框示例代码
Feb 22 Javascript
jquery+CSS3实现3D拖拽相册效果
Jul 18 Javascript
总结Javascript中数组各种去重的方法
Oct 04 Javascript
javascript中call,apply,bind函数用法示例
Dec 19 Javascript
基于vue+ bootstrap实现图片上传图片展示功能
May 17 Javascript
bootstrap插件treeview实现全选父节点下所有子节点和反选功能
Jul 21 Javascript
详解vue-cli中的ESlint配置文件eslintrc.js
Sep 25 Javascript
JS生成随机打乱数组的方法示例
Dec 23 Javascript
javascript与PHP动态往类中添加方法对比
Mar 21 Javascript
浅析java线程中断的办法
Jul 29 Javascript
ES6 新增的创建数组的方法(小结)
Aug 01 Javascript
js中console在一行内打印字符串和对象的方法
Sep 10 Javascript
Vue-router结合transition实现app前进后退动画切换效果的实例
Oct 11 #Javascript
jQuery实现的事件绑定功能基本示例
Oct 11 #jQuery
AngularJS中下拉框的高级用法示例
Oct 11 #Javascript
详解从Vue.js源码看异步更新DOM策略及nextTick
Oct 11 #Javascript
AngularJS中下拉框的基本用法示例
Oct 11 #Javascript
Node.js学习之TCP/IP数据通讯(实例讲解)
Oct 11 #Javascript
Bootstrap Tooltip显示换行和左对齐的解决方案
Oct 11 #Javascript
You might like
Yii中srbac权限扩展模块工作原理与用法分析
2016/07/14 PHP
2017年最好用的9个php开发工具推荐(超好用)
2017/10/23 PHP
ThinkPHP整合datatables实现服务端分页的示例代码
2018/02/10 PHP
PHP+RabbitMQ实现消息队列的完整代码
2019/03/20 PHP
laravel框架的安装与路由实例分析
2019/10/11 PHP
javascript IE中的DOM ready应用技巧
2008/07/23 Javascript
javascript HTMLEncode HTMLDecode的完整实例(兼容ie和火狐)
2009/06/02 Javascript
关于IE中getElementsByClassName不能用的问题解决方法
2013/08/26 Javascript
原生js ActiveXObject获取execl里面的值
2013/11/01 Javascript
JS记录用户登录次数实现代码
2014/01/15 Javascript
JavaScript中的document.referrer在各种浏览器测试结果
2014/07/18 Javascript
Bootstrap每天必学之js插件
2015/11/30 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
js生成随机颜色方法代码分享(三种)
2016/12/29 Javascript
基于Vuejs和Element的注册插件的编写方法
2017/07/03 Javascript
es7学习教程之fetch解决异步嵌套问题的方法示例
2017/07/21 Javascript
Node.js简单入门前传
2017/08/21 Javascript
基于bootstrap写的一点localStorage本地储存
2017/11/21 Javascript
JavaScript设计模式之调停者模式实例详解
2018/02/03 Javascript
jQuery-ui插件sortable实现自由拖动排序
2018/12/01 jQuery
在weex中愉快的使用scss的方法步骤
2020/01/02 Javascript
python Celery定时任务的示例
2018/03/13 Python
python 每天如何定时启动爬虫任务(实现方法分享)
2018/05/21 Python
Python统计分析模块statistics用法示例
2019/09/06 Python
如何基于python测量代码运行时间
2019/12/25 Python
python使用pandas抽样训练数据中某个类别实例
2020/02/28 Python
Python GUI编程学习笔记之tkinter控件的介绍及基本使用方法详解
2020/03/30 Python
CSS3实现10种Loading效果
2016/07/11 HTML / CSS
解决H5的a标签的download属性下载service上的文件出现跨域问题
2019/07/16 HTML / CSS
西尔斯百货官网:Sears
2016/09/06 全球购物
美国电子产品主要品牌的授权在线零售商:DataVision
2019/03/23 全球购物
俄罗斯商务邀请函
2014/01/26 职场文书
2014年中学生检讨书大全
2014/10/09 职场文书
绵山导游词
2015/02/05 职场文书
律师催款函范文
2015/06/24 职场文书
如何写一份成功的商业计划书
2019/06/25 职场文书