在Vue中,专门提供了一个名称为transition 的内置组件,来完成单个DOM元素的动画效果,该组件本身和它的顶层并不渲染动画效果,而只是将动画效果应用到被组件包裹的DOM元素上,代码实现的格式如下所示。
typescript
<transition>
<div>动画元素</div>
</transition>
transition 组件可以实现的动画包括过渡和自定义两种,底层都是由CSS3中的样式来完成的,在动画执行时,组件自动生成CSS3动画类名属性,格式为:
typescript
name-string
如:如果需要实现名称为fade的渐隐渐显过渡动画效果,则在样式类别为"fade-enter"和"fade-enter-active"中添加效果即可,下面通过一个示例来说明它的应用过程:
实例5-1 制作一个过渡动画
1. 功能描述
在页面中,分别添加一个按钮和一个transition元素,并在动画组件中包裹一个div元素,当首次点击按钮时,div元素以渐隐渐显的方式隐藏,再次点击按钮时,div元素以渐隐渐显的方式显示,同时,按钮中也显示相应的状态名称。
2. 实现代码
在项目components 文件夹的ch5子文件夹中,添加一个名为"TransBase"的.vue文件,在文件中加入如清单5-1所示代码。
代码清单5-1 TransBase.vue代码
typescript
<template>
<div class="action">
<div class="act">
<input type="button" @click="startTrans()"
:value="blnShow ? '隐藏动画' : '显示动画'">
</div>
<transition name="fade">
<div class="mytrans" v-if="blnShow"></div>
</transition>
</div>
</template>
<script>
export default {
name: "TransBase",
data() {
return {
blnShow: true
};
},
methods: {
startTrans() {
this.blnShow = !this.blnShow;
}
},
};
</script>
<style scoped>
.fade-enter-active,
.fade-leave-active {
transition: opacity 2s ease;
}
.fade-enter-from,
.fade-leave-to {
opacity: 0;
}
.action .act {
margin: 10px 0;
}
.action .act input {
width: 80px;
height: 32px;
}
.mytrans {
width: 200px;
height: 150px;
background-color: #666;
}
</style>
3. 页面效果
保存代码后,页面在Chrome浏览器下执行的页面效果如图5-1所示。
4. 源码分析
在上述示例的模板代码中,当向transition组件中添加或删除元素时,Vue 框架将自动检测transition组件是否添加了动画名称属性,如果添加了name属性并指定了动画名称,则向包裹元素添加或删除各类动画效果的CSS类别名,以实现包裹元素的动画效果;如果没有添加,则包裹元素将会直接显示或隐藏。
通常情况下,动画组件包含6个CSS类别名,它们的名称和使用说明如下表5.1所示。
需要说明的是:6个动画类别名称样式分为两大类,一类是进入,另一类是离开,每类3个CSS动画样式,每个样式的名称都会以动画名称作为前缀,如"fade-enter-from",如果没有指定动画名称,则以"v"作为前缀,如"v-enter-from"。
在示例中,页面加载完成时,动画元素的opacity 属性值为1,当点击按钮时,应用离开动画样式,且opacity 属性值为成为0,当再次点击按钮时,应用进入动画样式,使opacity 属性值为成为1,动画样式的整体实现流程如下图5-2所示。