首页 > 编程 > JavaScript > 正文

vue.js动画中的js钩子函数的实现

2019-11-19 13:32:31
字体:
来源:转载
供稿:网友

在transition中还可以通过设置javascript钩子函数,实现自定义动画效果。

以实现击球效果为例:

击球

代码解析:

<!-- 定义js的钩子函数 --><transition  @before-enter="beforeEnter"  @enter="enter"  @after-enter="afterEnter">  <img v-show="flag" class="ball" :src="ball" alt="" width="30"></transition>
let vm = new Vue({  el: "#app",  data: {    flag: false,    ball: 'https://upload-images.jianshu.io/upload_images/1864602-ec73f549171a6601.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240'  },  methods: {    // el 表示要执行动画的那个DOM元素, 是原生的 js DOM 对象    beforeEnter(el) {      // 设置动画开始之前的初始位置      el.style.transform = "translate(0, 0)"    },    enter(el, done) {      // 刷新动画效果      el.offsetWidth;      // 动画完成后的样式      el.style.transform = "translate(550px, 350px)";      // 动画的持续时间      el.style.transition = "all 3s ease";      // done 其实是 afterEnter() 的引用      done();    },    afterEnter(el) {      // 动画完成之后调用      this.flag = !this.flag    }  }})

完整代码

<!doctype html><html lang="en"><head>  <meta charset="UTF-8">  <link href="https://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet">  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script></head><style>  .container {    margin-top: 2%;  }  img.ball {    margin-left: 3%;  }</style><body><div class="container">  <div id="app">    <button class="btn btn-danger" @click="flag=!flag">击球</button>    <!-- 定义js的钩子函数 -->    <transition      @before-enter="beforeEnter"      @enter="enter"      @after-enter="afterEnter"    >      <img v-show="flag" class="ball" :src="ball" alt="" width="30">    </transition>  </div></div><script>  let vm = new Vue({    el: "#app",    data: {      flag: false,      ball: 'https://upload-images.jianshu.io/upload_images/1864602-ec73f549171a6601.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240'    },    methods: {      // el 表示要执行动画的那个DOM元素, 是原生的 js DOM 对象      beforeEnter(el) {        // 设置动画开始之前的初始位置        el.style.transform = "translate(0, 0)"      },      enter(el, done) {        // 刷新动画效果        el.offsetWidth;        // 动画完成后的样式        el.style.transform = "translate(550px, 350px)";        // 动画的持续时间        el.style.transition = "all 3s ease";        // done 其实是 afterEnter() 的引用        done();      },      afterEnter(el) {        // 动画完成之后调用        this.flag = !this.flag      }    }  })</script></body></html>

最终效果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表