在transition中还可以通过设置javascript钩子函数,实现自定义动画效果。
10年积累的成都做网站、网站建设、外贸营销网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有天桥免费网站建设让你可以放心的选择与我们合作。
以实现击球效果为例:
击球
代码解析:
<!-- 定义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: '/upload/otherpic59/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: '/upload/otherpic59/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>
最终效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
名称栏目:vue.js动画中的js钩子函数的实现
网页网址:https://www.cdcxhl.com/article44/jdhsee.html
成都网站建设公司_创新互联,为您提供关键词优化、网站内链、虚拟主机、微信小程序、Google、App设计
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联