点餐-加入购物车后小球动画

本文详细介绍使用Vue.js实现小球动画的过程,包括动画钩子函数的运用,如beforeEnter、enter和afterEnter,以及如何通过点击按钮控制动画的显示与隐藏。通过实例代码展示了如何设置小球的初始位置、动画效果和过渡时间。
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>小球动画</title>
 <script src="js/vue-2.4.0.js"></script>
 <style>
  .ball{
   width: 20px;
   height: 20px;
   border-radius: 50%;
   background: red;
  }
  /*.v-enter-active{
   animation-duration:500ms;
   animation-delay: 0ms;
   animation-fill-mode: forwards;
   animation-timing-function: linear;
   transform-origin: 0 0;
  }
  .v-leave{
   opacity: 0;
  }*/
 </style>
</head>
<body>
 <div id="app">
        <button @click="flag=!flag">加入购物车</button>
        <!--给transition绑定动画enter钩子事件-->
        <transition
        @before-enter="beforeEnter"
        @enter="enter"
        @after-enter="afterEnter">
            <div class="ball" v-show="flag"></div>
        </transition>
    </div>
 <script>
        var vm = new Vue({
            el: "#app",
            data: {
                flag: false
            },
            methods: {
                //动画钩子函数
                //注意:动画钩子函数的第一个参数el,表示要执行动画的那个dom元素,是个原生dom元素
                beforeEnter(el) {
                //    表示动画入场之前,此时,动画尚未开始,可以在beforeEnterz中设置元素开始动画之前的启示样式
                    el.style.transform = "translate(0,0)"
                //    设置小球开始动画之前的起始位置
                },
                enter(el,done) {
                    //此处的done代表下一个钩子函数,在调用done之后会直接调用afterEnter函数(),不调用小球会延迟消失
                    //必须加上才有动画。黑魔法
                    el.offsetLeft;//或者时offsetWidth||offsetHeight||offsetRight
                //enter 表示动画开始之后的样式,这里可以设置小球完成动画之后的结束状态
                    el.style.transform = "translate(150px,450px)";
                    el.style.transition = "all 1s ease";
                    done()
                },
                afterEnter(el) {
                    //在执行完成之后小球会等一会消失
                    this.flag = !this.flag;
                }
            }
        })
    </script>
</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值