要求:要通过Vue使用过渡动画我们要把需要过度的元素放在<transition name='变量名'></transition>中。

原理:通过在特定的时刻增加/移除样式实现。

一、Vue中的过度效果

1.未声明name,Vue默认添加/移除v-enter,v-leave-to,v-enter-active,v-leave-active来实现

v-enter决定元素在加入dom时的样式

v-enter-active决定样式执行状态

v-leave-to对应移除的

实例:为元素添加显示隐藏的过度效果

<style>
.v-enter,.v-leave-to{
opacity: 0;
}
.v-enter-active,.v-leave-active{
transition: opacity 1s;
}
</style>
</head>
<body>
<div id="app">
<transition>
<h3 v-if="show">Hi Boy</h3>
</transition>
<button @click="handleClick">DoIt</button>
</div>
</body>
<script> var app=new Vue({
el:'#app',
data:{
show:true
},
methods:{
handleClick:function(){
this.show=!this.show
}
}
})
</script>

2.如果声明了对应的name则可以改写为

css:

<style>
.fade-enter,.fade-leave-to{
opacity:;
}
.fade-enter-active,.fade-leave-active{
transition: opacity 1s;
}
</style>

html:

<div id="app">
<transition name="fade">
<h3 v-if="show">Hi Boy</h3>
</transition>
<button @click="handleClick">DoIt</button>
</div>

二、Vue中的动画效果

1.使用自定义动画

html不变,关键是css变为如下

@keyframes myfade{
from{opacity:}
to{opacity:}
}
.fade-enter-active{
animation: myfade 1s;
}
.fade-leave-active{
animation: myfade 1s reverse;
}

实现效果一样,此时我们用的动画,当然动画还有很多效果。

2.采用Animate.css库文件实现动画

使用库文件时我们需要知道除了通过那么调用的另一种调用方法

直接在class中自定义调用的样式

css:

@keyframes myfade{
from{opacity:}
to{opacity:}
}
.enter{
animation: myfade 1s;
}
.leave{
animation: myfade 1s reverse;
}

html:

<transition name="fade"
enter-active-class="enter"
leave-active-class="leave"
>
<h3 v-if="show">Hi Boy</h3>
</transition>

此时的enter和leave时我们完全自定义的样式名。

如果向调用animate.css库只需要改写html

如下:

<transition name="fade"
enter-active-class="animated bounce"
leave-active-class="animated bounce"
>
<h3 v-if="show">Hi Boy</h3>
</transition>

bounce未调用的动画名。提示前面必须加animated。

具体想要使用什么动画请看animate.css官网

提示:如果想要在页面初始化时播放动画需要添加appear和appear-active-class

<transition name="fade"
appear
enter-active-class="animated shake"
leave-active-class="animated bounce"
appear-active-class="animated shake"
>
<h3 v-if="show">Hi Boy</h3>
</transition>

三、过度效果和动画效果混用

例子如下:

<style>
@keyframes myfade{
from{opacity: 0}
to{opacity: 1}
}
.fade-enter,.fade-leave-to{
opacity: 0;
}
.fade-enter-active,.fade-leave-active{
transition: opacity 3s;
}
</style>
</head>
<body>
<div id="app">
<transition name="fade"
appear
enter-active-class="animated shake fade-enter-active"
leave-active-class="animated bounce fade-leave-active"
appear-active-class="animated shake"
>
<h3 v-if="show">Hi Boy</h3>
</transition>
<button @click="handleClick">DoIt</button>
</div>
</body>

警告:此时opacity过渡动画是3秒,animate.css动画未1秒,执行时间不统一。

解决方法:添加type属性如

type="transition" 以过度效果执行时间执行

type="animation"以动画效果执行时间执行

<transition name="fade" type="transition"
appear
enter-active-class="animated shake fade-enter-active"
leave-active-class="animated bounce fade-leave-active"
appear-active-class="animated shake"
>

2.自定义动画时间

:duration="时长(毫秒)"一般定义

:duration="{enter:1000,leave:2000}"//分别定义出场和入场时长

<transition name="fade" :duration="10000"
appear
enter-active-class="animated shake fade-enter-active"
leave-active-class="animated bounce fade-leave-active"
appear-active-class="animated shake"
>
<h3 v-if="show">Hi Boy</h3>
</transition>

Vue过渡动画—Vue学习笔记的更多相关文章

  1. (学习心路历程)Vue过渡/动画 VS. 过渡/动画

    [此篇为本人的个人见解和哔哔赖赖,如果有观点不对的地方,还请大家指出来哇!!] 最近实习在做一个项目,里面应用的动画效果还蛮复杂的,因为本身对Vue框架比较熟悉,所以最终选择了Vue框架. 自己之前从 ...

  2. Vue.js 源码学习笔记

    最近饶有兴致的又把最新版 Vue.js 的源码学习了一下,觉得真心不错,个人觉得 Vue.js 的代码非常之优雅而且精辟,作者本身可能无 (bu) 意 (xie) 提及这些.那么,就让我来吧:) 程序 ...

  3. vue过渡动画

    概述 Vue 在插入.更新或者移除 DOM 时,提供多种不同方式的应用过渡效果.包括以下工具: 在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS 动画库,如 Animate.c ...

  4. vue过渡动画效果

    1 过渡基础 1.1 过渡的方式 Vue 在插入.更新或者移除 DOM 时,提供多种不同方式的应用过渡效果. 包括以下工具: 在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS ...

  5. vue过渡 & 动画---进入/离开 & 列表过渡

    (1)概述 Vue 在插入.更新或者移除 DOM 时,提供多种不同方式的应用过渡效果.包括以下工具: 在 CSS 过渡和动画中自动应用 class 可以配合使用第三方 CSS 动画库,如 Animat ...

  6. Vue过渡动画运用transition

    vue的过渡动画,主要是transition标签的使用,配合css动画实现的.官方文档css过渡 通过点击事件来切换show的值来改变显示的文本,下面的css通过进入离开时的在匀速状态下xxs(秒)下 ...

  7. Vue.js 第3章 axios&Vue过渡动画

    promise 它将我们从回调地狱中解脱出来 创建和使用 var fs = require('fs') // 创建promise // reslove表示执行成功后调用的回调函数 // reject表 ...

  8. vue 过渡 & 动画

    过渡 & 动画 过渡动画 用css先定义好动画效果 .a-enter-active, .a-leave-active { transition: all 1.5s; } .a-enter, . ...

  9. vue过渡动画样式

    在进入/离开的过渡中,会有 6 个 class 切换. v-enter:定义进入过渡的开始状态.在元素被插入之前生效,在元素被插入之后的下一帧移除. v-enter-active:定义进入过渡生效时的 ...

随机推荐

  1. 27 isinstance与issubclass、反射、内置方法

    isinstance与issubclass issubclass:判断子类是否属于父类,是则返回True,否则返回False isinstance:判断对象是否属于类,是则返回True,否则返回Fal ...

  2. centos7 sqoop 1 搭建笔记

    1.require : java环境,hadoop,hive ,mysql2.下载解压sqoop13.设置环境变量 export SQOOP_HOME=/data/spark/bin/sqoop ex ...

  3. hadoop mapreduce 写入hbase报错 Session 0x0 for server null, unexpected error, closing socket connection and attempting reconnect

    现象:map任务构造数据正常,reduce任务,开始也正常,速度很快 ,在hbase 的管理界面,可以看到,5W以上的请求数 当reduce 执行到 70% 左右的时候,就堵住了,查看yarn的web ...

  4. PHP 正则表达式--转(川山甲)

    思维导图    点击下图,可以看具体内容!     介绍          正则表达式,大家在开发中应该是经常用到,现在很多开发语言都有正则表达式的应用,比如javascript,java,.net, ...

  5. UVa 11077 Find the Permutations (计数DP)

    题意:给定 n 和 m,问你在 1 ~ n 的所有排列中,有多少个排列满足至少要交换 m 次才能变成 1 2 3 ... n. 析:首先,先考虑一下,某个排列,要变成 1 2 3 .. n,最少要交换 ...

  6. BZOJ 4129 Haruna’s Breakfast (分块 + 带修莫队)

    4129: Haruna’s Breakfast Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 835  Solved: 409[Submit][St ...

  7. ACtiveMQ中间件-消息的接收和发送

    一.发送消息基本步骤 (1)启动ActiveMQ的的activemq.bat批处理文件或BrokerService节点 (2)创建连接使用的工厂类ActiveMQConnectionFactory通过 ...

  8. 20155205《Java程序设计》实验五(网络编程与安全)实验报告

    20155205 <Java程序设计>实验五(网络编程与安全)实验报告 一.实验内容及步骤 (一) 两人一组结对编程 参考http://www.cnblogs.com/rocedu/p/6 ...

  9. WEB上传大文件解决方案

    众所皆知,web上传大文件,一直是一个痛.上传文件大小限制,页面响应时间超时.这些都是web开发所必须直面的. 本文给出的解决方案是:前端实现数据流分片长传,后面接收完毕后合并文件的思路.下面贴出简易 ...

  10. 屏幕抓取程序 (位图DDB的例子)

    屏幕抓取程序的意思是将整个屏幕图显示在应用程序的用户区中,等价于截图.对桌面窗口的操作:首先得知道桌面窗口的宽和高,获取宽和高需要利用窗口的设备句柄,而获取设备句柄需要知道窗口句柄,这一系列的连串关系 ...