leiyanting

导航

 

Vue封装的过度与动画

  1. 作用:在插入、更新或移除 DOM元素时,在合适的时候给元素添加样式类名。

  2. 写法:

    1. 准备好样式:

      • 元素进入的样式:
        1. v-enter:进入的起点
        2. v-enter-active:进入过程中
        3. v-enter-to:进入的终点
      • 元素离开的样式:
        1. v-leave:离开的起点
        2. v-leave-active:离开过程中
        3. v-leave-to:离开的终点
    2. 使用<transition>包裹要过度的元素,并配置name属性:

      <transition name="hello">
      	<h1 v-show="isShow">你好啊!</h1>
      </transition>
      
    3. 备注:若有多个元素需要过度,则需要使用:<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>

 

posted on 2021-11-20 10:12  leiyanting  阅读(39)  评论(0编辑  收藏  举报