Vuetransition 标签的使用
Posted JS.Huang
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vuetransition 标签的使用相关的知识,希望对你有一定的参考价值。
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)
配合 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>
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>
- 当存在多个
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>
- 也可以将
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%);
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>
- 如果只有两个元素,也可以给一个元素的
key
设置不同的状态来代替v-if
和v-else
,上面的例子可以重写为:
<transition>
<h1 :key="isEditing">
isEditing ? "Save" : "Edit"
</h1>
</transition>
动画库 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>
提交后渲染列表时如何解决转换组的问题
【中文标题】提交后渲染列表时如何解决转换组的问题【英文标题】:how to fix problem with transition-group when rendering list after submit 【发布时间】:2019-06-02 15:14:07 【问题描述】:实际上我在使用 vue transition-group 提交表单后渲染更新列表时遇到了麻烦
当我使用简单的“ul”标签时没有问题,但是当我想通过转换组进行转换时,控制台出现错误
" 子级必须使用 :li 键控。
<transition-group name="list-complete" tag="ul" class="list">
<li class="item list-complete-item " v-for="contact in contacts" v-bind:key="contact.id">
<div class="item__desc">
<p class="paragraph">
<span class="bold">contact.name</span>
</p>
<p class="paragraph">
<span class="bold">Mail:</span>
contact.email
</p>
<p class="paragraph">
<span class="bold">Street:</span>
contact.address.street
</p>
<p class="paragraph">
<span class="bold">City:</span>
contact.address.city
</p>
</div>
</li>
【问题讨论】:
contact.id
可能在一次或多次迭代中未定义。
哦,是的,你说得对。列表中的传入项目没有“id”,所以我将 v:bind:key 更改为更独特。非常感谢
【参考方案1】:
尝试将您的 key
绑定到 index
等唯一数据,如下所示:
<li class="item list-complete-item " v-for="(contact,index) in contacts" v-bind:key="index">
如official docs
中所述:
用法:
<transition-group>
用作多个元素/组件的过渡效果。 ><transition-group>
呈现一个真实的 DOM 元素。默认情况下它渲染一个<span>
,你可以通过标签属性配置它应该渲染的元素。请注意,
<transition-group>
中的每个孩子都必须唯一键控,动画才能正常工作。
【讨论】:
以上是关于Vuetransition 标签的使用的主要内容,如果未能解决你的问题,请参考以下文章
如何在 nuxt.js (vue.js) 中配置动态 og 标签?