transition
标签
transition
标签:Vue app开发定制公司的内置动画标签- 作用:在 [插入] / [更新] / [移除] DOM 元素时,app开发定制公司在合适的时候给元素添app开发定制公司加样式类名(配合 CSS 样式使用,app开发定制公司实现动画效果)
注意事项
transition
标签只能包含 1 个元素;如果里面写了多个元素,则只生效第一个transition
包裹的标签需要设置v-show
/v-if
属性控制元素的显示
动画 CSS 样式对应的类名
-
进入:
.v-enter
始状态、.v-enter-to
末状态、.v-enter-active
进入动画() -
离开:
.v-leave
始状态、.v-leave-to
末状态、.v-leave-active
离开动画(Vue2) -
进入:
.v-enter-from
始状态、.v-enter-to
末状态、.v-enter-active
进入动画() -
离开:
.v-leave-from
始状态、.v-leave-to
末状态、.v-leave-active
离开动画(Vue3)
配合 animation
<template> <div> <button @click="bol = !bol">隐藏/显示</button> <!-- Vue 的内置动画标签 transition --> <transition> <!-- 只能包含 1 个元素 --> <h1 v-show="bol">组件动画效果</h1> <!-- 需要设置 v-show / v-if 属性控制元素的显示 --> </transition> </div></template><script>export default { name: "App", data() { return { bol: true }; },};</script><style>/* 进入动画 */.v-enter-active { animation: move 1s;}/* 离开动画 */.v-leave-active { animation: move 1s reverse;}@keyframes move { from { transform: translateX(-100%); } to { transform: translate(0); }}</style>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
transition 标签的属性
-
name
属性:用于自动生成 CSS 动画类名如果
transition
标签元素没有设置name
属性,则对应的动画类名为v-XXX
如果设置了
name
属性,则对应的动画类名为属性值-XXX
-
appear
属性:一开始就生效显示动画
<template> <div> <button @click="bol = !bol">隐藏/显示</button> <!-- transition 标签元素设置了 name、appear 属性 --> <transition name="moveCartoon" appear> <!-- 动画会在一开始便生效 --> <h1 v-show="bol">组件动画效果</h1> </transition> </div></template><script>export default { name: "App", data() { return { bol: true }; },};</script><style>/* 类名要对应回 name 的属性值 */.moveCartoon-enter-active { animation: move 1s;}.moveCartoon-leave-active { animation: move 1s reverse;}@keyframes move { from { transform: translateX(-100%); } to { transform: translate(0); }}</style>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 当存在多个
tansition
标签时,我们可以通过name
属性给各个transition
标签指定不同的 CSS 动画效果
配合 transition
<template> <div id="app"> <button @click="bol = !bol">隐藏/显示</button> <transition appear> <h1 v-show="bol">组件动画</h1> </transition> </div></template><script>export default { name: "App", data() { return { bol: true }; },};</script><style>/* 进入:始状态 */.v-enter { transform: translateX(-100%);}/* 进入:末状态 */.v-enter-to { transform: translateX(0);}/* 进入动画 */.v-enter-active { transition: 1s;}/* 离开:始状态 */.v-leave { transform: translateX(0);}/* 离开:末状态 */.v-leave-to { transform: translateX(-100%);}/* 离开动画 */.v-leave-active { transition: 1s;}</style>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 也可以将
transition: 1s;
设置到标签上,就不用写v-leave-active
、v-enter-active
对应的样式了
h1 { transition: 1s;}/* 进入:始位置 */.v-enter { transform: translateX(-100%);}/* 进入:末位置 */.v-enter-to { transform: translateX(0);}/* 离开:始位置 */.v-leave { transform: translateX(0);}/* 离开:末位置 */.v-leave-to { transform: translateX(-100%);}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
transition-group
标签
- transition 标签只能包含 1 个元素、 transition-group 标签可以包含多个元素
- transition-group 标签里面的元素需要设置
key
属性,作为当前元素的唯一标识 - 除此之外,其他用法都和 transition 标签一样
<template> <div id="app"> <button @click="isEditing = !isEditing">切换</button> <transition-group appear> <h1 v-if="isEditing" key="save">Save</h1> <h1 v-if="!isEditing" key="edit">Edit</h1> </transition-group> </div></template><script>export default { name: "App", data() { return { isEditing: true }; },};</script><style>h1 { transition: 0.5s; position: absolute;}.v-leave { opacity: 1;}.v-leave-to { opacity: 0;}.v-enter { opacity: 0;}.v-enter-to { opacity: 1;}</style>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 如果只有两个元素,也可以给一个元素的
key
设置不同的状态来代替v-if
和v-else
,上面的例子可以重写为:
<transition> <h1 :key="isEditing"> {{ isEditing ? "Save" : "Edit" }} </h1></transition>
- 1
- 2
- 3
- 4
- 5
动画库 animate.css
- 下载:
npm install animate.css
- 引入样式库:
import "animate.css"
- 给指定的 transition 标签添加
name
属性animate_animate
、animate__bounce
- 配置
enter-active-class
属性,指定进入动画:
在样式库中挑一个进入的样式值,作为enter-active-class
属性值 - 配置
leave-active-class
属性,指定退出动画:
在样式库中挑一个退出的样式值,作为leave-active-class
属性值
<template> <div> <button @click="bol = !bol">隐藏 / 显示</button> <transition name="animate__animated animate__bounce" enter-active-class="animate__bounceIn" leave-active-class="animate__bounceOut" > <h1 v-show="bol">动画库的使用</h1> </transition> </div></template><script>import "animate.css"; // 引入样式库export default { name: "App", data() { return { bol: true }; },};</script>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22