Vuetransition 标签的使用

Posted JS.Huang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vuetransition 标签的使用相关的知识,希望对你有一定的参考价值。

transition 标签

  • transition 标签:Vue 的内置动画标签
  • 作用:在 [插入] / [更新] / [移除] DOM 元素时,在合适的时候给元素添加样式类名(配合 CSS 样式使用,实现动画效果)

注意事项

  • transition 标签只能包含 1 个元素;如果里面写了多个元素,则只生效第一个
  • transition 包裹的标签需要设置 v-show / v-if 属性控制元素的显示

动画 CSS 样式对应的类名

  1. 进入:.v-enter 始状态、.v-enter-to 末状态、.v-enter-active 进入动画(Vue2)

  2. 离开:.v-leave 始状态、.v-leave-to 末状态、.v-leave-active 离开动画(Vue2)

  3. 进入:.v-enter-from 始状态、.v-enter-to 末状态、.v-enter-active 进入动画(Vue3)

  4. 离开:.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 标签的属性

  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>
            <!-- 动画会在一开始便生效 -->
            <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-activev-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-ifv-else,上面的例子可以重写为:
<transition>
    <h1 :key="isEditing">
         isEditing ? "Save" : "Edit" 
    </h1>
</transition>

动画库 animate.css

  1. 下载:npm install animate.css
  2. 引入样式库:import "animate.css"
  3. 给指定的 transition 标签添加 name 属性 animate_animateanimate__bounce
  4. 配置 enter-active-class 属性,指定进入动画:
    在样式库中挑一个进入的样式值,作为 enter-active-class 属性值
  5. 配置 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 中所述:

用法:

&lt;transition-group&gt; 用作多个元素/组件的过渡效果。 >&lt;transition-group&gt; 呈现一个真实的 DOM 元素。默认情况下它渲染一个&lt;span&gt;,你可以通过标签属性配置它应该渲染的元素。

请注意,&lt;transition-group&gt; 中的每个孩子都必须唯一键控,动画才能正常工作。

【讨论】:

以上是关于Vuetransition 标签的使用的主要内容,如果未能解决你的问题,请参考以下文章

如何设置 vue.js 忽略锚标签?

模板中带有脚本标签的广告 [Vue.js]

如何在 nuxt.js (vue.js) 中配置动态 og 标签?

select 标签 未选择任何内容 在 vue.js 中使用遇到的坑

如何在 Vue.js 中保留自定义组件标签名称

Vue.js——循环(JavaJSTL标签库数据库)