微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

以实现击球效果为例:

代码解析:

rush:js;">
rush:js;"> 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 } } })

完整代码

rush:xhtml;"> <Meta charset="UTF-8"> nofollow" rel="stylesheet">

最终效果

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

原文地址:https://www.jb51.cc/vue/31637.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐