这篇文章主要讲解了“Vue中transition标签如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中transition标签如何使用”吧!
transition 标签:Vue 的内置动画标签
作用:在 [插入] / [更新] / [移除] DOM 元素时,在合适的时候给元素添加样式类名(配合 CSS 样式使用,实现动画效果)
注意事项
transition 标签只能包含 1 个元素;如果里面写了多个元素,则只生效第一个
transition 包裹的标签需要设置 v-show
/ v-if
属性控制元素的显示
动画 CSS 样式对应的类名
进入:.v-enter
始状态、.v-enter-to
末状态、.v-enter-active
进入动画(Vue2)
离开:.v-leave
始状态、.v-leave-to
末状态、.v-leave-active
离开动画(Vue2)
进入:.v-enter-from
始状态、.v-enter-to
末状态、.v-enter-active
进入动画(Vue3)
离开:.v-leave-from
始状态、.v-leave-to
末状态、.v-leave-active
离开动画(Vue3)
<template> <div> <button @click="bol = !bol">隐藏/显示</button> <!-- Vue 的内置动画标签 transition --> <transition> <!-- 只能包含 1 个元素 --> <h2 v-show="bol">组件动画效果</h2> <!-- 需要设置 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>
transition 标签的属性
1、name 属性:用于自动生成 CSS 动画类名
如果 transition
标签元素没有设置 name
属性,则对应的动画类名为 v-XXX
如果设置了 name
属性,则对应的动画类名为 属性值-XXX
2、appear 属性:一开始就生效显示动画
<template> <div> <button @click="bol = !bol">隐藏/显示</button> <!-- transition 标签元素设置了 name、appear 属性 --> <transition name="moveCartoon" appear> <!-- 动画会在一开始便生效 --> <h2 v-show="bol">组件动画效果</h2> </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>
当存在多个 tansition
标签时,我们可以通过 name
属性给各个 transition
标签指定不同的 CSS 动画效果
<template> <div id="app"> <button @click="bol = !bol">隐藏/显示</button> <transition appear> <h2 v-show="bol">组件动画</h2> </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>
也可以将 transition: 1s;
设置到标签上,就不用写 v-leave-active
、v-enter-active
对应的样式了
h2 { transition: 1s; } /* 进入:始位置 */ .v-enter { transform: translateX(-100%); } /* 进入:末位置 */ .v-enter-to { transform: translateX(0); } /* 离开:始位置 */ .v-leave { transform: translateX(0); } /* 离开:末位置 */ .v-leave-to { transform: translateX(-100%); }
transition 标签只能包含 1 个元素、 transition-group 标签可以包含多个元素
transition-group 标签里面的元素需要设置 key
属性,作为当前元素的唯一标识
除此之外,其他用法都和 transition 标签一样
<template> <div id="app"> <button @click="isEditing = !isEditing">切换</button> <transition-group appear> <h2 v-if="isEditing" key="save">Save</h2> <h2 v-if="!isEditing" key="edit">Edit</h2> </transition-group> </div> </template> <script> export default { name: "App", data() { return { isEditing: true }; }, }; </script> <style> h2 { transition: 0.5s; position: absolute; } .v-leave { opacity: 1; } .v-leave-to { opacity: 0; } .v-enter { opacity: 0; } .v-enter-to { opacity: 1; } </style>
如果只有两个元素,也可以给一个元素的 key
设置不同的状态来代替 v-if
和 v-else
,上面的例子可以重写为:
<transition> <h2 :key="isEditing"> {{ isEditing ? "Save" : "Edit" }} </h2> </transition>
下载: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" > <h2 v-show="bol">动画库的使用</h2> </transition> </div> </template> <script> import "animate.css"; // 引入样式库 export default { name: "App", data() { return { bol: true }; }, }; </script>
感谢各位的阅读,以上就是“Vue中transition标签如何使用”的内容了,经过本文的学习后,相信大家对Vue中transition标签如何使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。