vue.js动画中的js钩子函数的实现
网络编程 2021-07-04 16:46www.168986.cn编程入门
这篇文章主要介绍了vue.js动画中的js钩子函数的实现,长沙网络推广觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随长沙网络推广过来看看吧
在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./bootstrap/3.3.7/css/bootstrap.min.css" rel="external nofollow" rel="stylesheet"> <script src="https://cdn.jsdelivr./npm/vue/dist/vue.js"></script> </head> <style> .container { margin-: 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>
最终效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:jQuery实现仿京东防抖动菜单效果示例
下一篇:老生常谈JS中的继承及实现代码
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程