vue动画钩子函数

下面来个半场动画的例子

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>vue动画</title>
    <script src="./lib/vue.2.6.6.js"></script>
    <style>
        #grou {
            background-color: #F00;
            width: 15px;
            height: 15px;
            border-radius: 50%;
        }
    </style>
</head>

<body>
    <div id="app">
        <button @click="flag = ! flag">点我</button>
        <transition @before-enter="beforeEnter" @enter="enter" @after-enter="afterEnter">
            <div id="grou" v-if="flag"></div>
        </transition>
    </div>
</body>
<script>
    var myapp = new Vue({
        el: "#app",
        data: {
            flag: false,
        },
        methods: {
            //vue动画钩子函数的第一个参数el表示要执行动画的DOM元素
            beforeEnter(el) {//动画入场之前,可以在这里设置元素动画入场之前的样式
                el.style.transform = "translate(0,0)"
            },
            enter(el, done) {//动画入场,这里的done就是 afterEnter 动画完成之后立即调用afterEnter,官网是这么解释的:(当只用 JavaScript 过渡的时候,在 enter 和 leave 中必须使用 done 进行回调。否则,它们将被同步调用,过渡会立即完成。)
                el.offsetWidth //这句话貌似没什么用,但是不写没有动画效果
                el.style.transform = "translate(150px,200px)"
                el.style.transition = "all 1s ease"
                done()
            },
            afterEnter(el) {//动画入场之后
                //动画结束之后元素消失
                this.flag = !this.flag
            }
        },
    })
</script>

</html>

猜你喜欢

转载自blog.csdn.net/xingxingxingge/article/details/87741041