<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>vue中的css动画原理</title>
    <script src="./vue.js"></script>
    <style>
        .fade-enter,.fade-leave-to{
            opacity: 0;
        }
        .fade-enter-active,.fade-leave-active{
            transition : opacity 3s;
        }
    </style>
</head>
<body>
<div id="root">
    <!--当元素被transition标签包起来的时候Vue会自动构建一个动画流程-->
    <transition name="fade">
        <div v-if="show">hello world</div>
    </transition>
    <button @click="hendleClick">切换</button>
</div>
<script>
    let vm = new Vue({
        el : '#root',
        data : {
            show : true
        },
        methods : {
            hendleClick : function(){
                this.show = !this.show
            }
        }
    })
</script>
</body>
</html>

显示原理:当一个元素被 transition 包裹了之后,vue会自动当分析元素的css样式,然后构建一个动画的流程,在动画即将被执行的一瞬间(也就是事件触发后元素出现),vue会在内部标签上增加两个class名字,分别是 fade-enter,fade-enter-active,在动画执行到第二帧的时候,也就是动画开始后,fade-enter会变成 fade-enter-to,动画执行到最后到时候,vue会干一件事情,把之前添加到fade-enter-to,fade-enter-active这两个class去除掉(如图1)

第0s的时候样式由fade-enter控制,透明度为0,当第二帧的时候,透明度在3s内由0到1过度,如果transition的name不写,默认样式是v-enter, v-enter-active

隐藏原理:当一个元素被transition包裹了之后,元素由显示到隐藏,是这样一个流程,在隐藏的第一个瞬间,vue会给元素新增两个class,fade-leave,fade-leave-active,在第二帧的时候,会把fade-leave去掉,更新为fade-leave-to,在最后的时候,会把fade-leave-to,fade-leave-active都去除掉(事件执行元素消失)

从动画开始到结束,fade-leave-active都存在,也就是在动画运行的过程中,时刻监听着这个opacity这个属性,一旦opacity发生变化,就让opacity在3s中慢慢的进行过度,在第一瞬间,也就是fade-leave的时候,opacity还是显示的,为1

这种动画效果,叫做过渡的动画效果,也叫css动画

posted on 2019-09-24 17:19  yu_bin  阅读(384)  评论(0编辑  收藏  举报