Vue封装的过度与动画
-
作用:在插入、更新或移除 DOM元素时,在合适的时候给元素添加样式类名。
-
写法:
-
准备好样式:
- 元素进入的样式:
- v-enter:进入的起点
- v-enter-active:进入过程中
- v-enter-to:进入的终点
- 元素离开的样式:
- v-leave:离开的起点
- v-leave-active:离开过程中
- v-leave-to:离开的终点
- 元素进入的样式:
-
使用
<transition>
包裹要过度的元素,并配置name属性:<transition name="hello"> <h1 v-show="isShow">你好啊!</h1> </transition>
-
备注:若有多个元素需要过度,则需要使用:
<transition-group>
,且每个元素都要指定key
值。
-
使用动画方式
<template> <div> <button @click="isShow = !isShow">显示/隐藏</button> <!-- appear 当页面挂载后立即执行一次进入动画 --> <!-- 如果不写name那么就是v-enter-active这种,写了name则可以与之区分,必写 --> <transition name="hello" appear> <h1 v-show="isShow">你好啊!</h1> </transition> </div> </template> <script> export default { name:'Test', data() { return { isShow:true } }, } </script> <style scoped> /* 使用动画方式 */ h1{ background-color: orange; } .hello-enter-active{ animation: atguigu 0.5s linear; } .hello-leave-active{ animation: atguigu 0.5s linear reverse; } @keyframes atguigu { from{ transform: translateX(-100%); } to{ transform: translateX(0px); } } </style>
使用过渡来实现动画
<template> <div> <button @click="isShow = !isShow">显示/隐藏</button> <!-- appear 当页面挂载后立即执行一次进入动画 --> <!-- transition-group标签则是可以在其中之内包含多个需要执行动画的元素,但是必须添加key值 --> <!-- 如果不写name那么就是v-enter-active这种,写了name则可以与之区分,必写 --> <transition-group name="hello" appear> <h1 v-show="!isShow" key="1">你好啊!</h1> <h1 v-show="isShow" key="2">尚硅谷!</h1> </transition-group> </div> </template> <script> export default { name:'Test', data() { return { isShow:true } }, } </script> <style scoped> /* 使用过渡来实现动画 */ h1{ background-color: orange; } /* 进入的起点、离开的终点 */ .hello-enter,.hello-leave-to{ transform: translateX(-100%); } .hello-enter-active,.hello-leave-active{ transition: 0.5s linear; } /* 进入的终点、离开的起点 */ .hello-enter-to,.hello-leave{ transform: translateX(0); } </style>
使用第三方库来实现动画
<template> <div> <button @click="isShow = !isShow">显示/隐藏</button> <!-- name中填写的是animate必写的class内容, 然后enter-active-class就是进入过程使用的class样式, leave-active-class是离开过后才能中使用的class样式 --> <transition-group appear name="animate__animated animate__bounce" enter-active-class="animate__swing" leave-active-class="animate__backOutUp" > <h1 v-show="!isShow" key="1">你好啊!</h1> <h1 v-show="isShow" key="2">尚硅谷!</h1> </transition-group> </div> </template> <script> // 使用第三方库来实现动画 import 'animate.css' export default { name:'Test', data() { return { isShow:true } }, } </script> <style scoped> h1{ background-color: orange; } </style>