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


Posted in Javascript onJuly 06, 2018

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

以实现击球效果为例:

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

击球

代码解析:

<!-- 定义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>

最终效果:

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
input的focus方法使用
Mar 13 Javascript
js中的push和join方法使用介绍
Oct 08 Javascript
JQuery实现动态表格点击按钮表格增加一行
Aug 24 Javascript
理解和运用JavaScript的闭包机制
Aug 13 Javascript
JavaScript比较当前时间是否在指定时间段内的方法
Aug 02 Javascript
基于Require.js使用方法(总结)
Oct 26 Javascript
vue-router命名视图的使用讲解
Jan 19 Javascript
JavaScript模块管理的简单实现方式详解
Jun 15 Javascript
el-select 下拉框多选实现全选的实现
Aug 02 Javascript
Layui table field初始化加载时进行隐藏的方法
Sep 19 Javascript
JS数组reduce()方法原理及使用技巧解析
Jul 14 Javascript
彻底搞懂并解决vue-cli4中图片显示的问题实现
Aug 31 Javascript
老生常谈JS中的继承及实现代码
Jul 06 #Javascript
vue.js使用v-if实现显示与隐藏功能示例
Jul 06 #Javascript
vue.js计算属性computed用法实例分析
Jul 06 #Javascript
vue.js实现的绑定class操作示例
Jul 06 #Javascript
vue.js实现插入数值与表达式的方法分析
Jul 06 #Javascript
详解浏览器缓存和webpack缓存配置
Jul 06 #Javascript
JS获取子节点、父节点和兄弟节点的方法实例总结
Jul 06 #Javascript
You might like
PHP个人网站架设连环讲(四)
2006/10/09 PHP
PHP简介
2006/10/09 PHP
PHP错误WARNING: SESSION_START() [FUNCTION.SESSION-START]解决方法
2014/05/04 PHP
php几个预定义变量$_SERVER用法小结
2014/11/07 PHP
PHP实现简易blog的制作
2016/10/24 PHP
php版微信小店调用api示例代码
2016/11/12 PHP
360搜索引擎自动收录php改写方案
2018/04/28 PHP
php实现数字补零的方法总结
2018/09/12 PHP
javascript 命名空间以提高代码重用性
2008/11/13 Javascript
JavaScript 乱码问题
2009/08/06 Javascript
eval与window.eval的差别分析
2011/03/17 Javascript
javascript函数以及基础写法100多条实用整理
2013/01/13 Javascript
jQuery cdn使用介绍
2013/05/08 Javascript
js、css、img等浏览器缓存问题的2种解决方案
2013/10/23 Javascript
提升PHP安全:8个必须修改的PHP默认配置
2014/11/17 Javascript
JS定义网页表单提交(submit)的方法
2015/03/20 Javascript
原生js实现图片层叠轮播切换效果
2016/02/02 Javascript
微信小程序 绘图之饼图实现
2016/10/24 Javascript
ES6概念 ymbol.for()方法
2016/12/25 Javascript
JS去掉字符串前后空格或去掉所有空格的用法
2017/03/25 Javascript
Angular4项目中添加i18n国际化插件ngx-translate的步骤详解
2017/07/02 Javascript
vue-star评星组件开发实例
2018/03/01 Javascript
详解promise.then,process.nextTick, setTimeout 以及 setImmediate的执行顺序
2018/11/21 Javascript
微信小程序全局变量GLOBALDATA的定义和调用过程解析
2019/09/23 Javascript
Hadoop中的Python框架的使用指南
2015/04/22 Python
详解Python之unittest单元测试代码
2018/01/24 Python
python实现机器学习之元线性回归
2018/09/06 Python
Python合并同一个文件夹下所有PDF文件的方法
2019/03/11 Python
Django 实现前端图片压缩功能的方法
2019/08/07 Python
执行Django数据迁移时报 1091错误及解决方法
2019/10/14 Python
Python为何不支持switch语句原理详解
2020/10/21 Python
Melijoe时尚童装德国官网:Melijoe德国
2016/09/03 全球购物
中专生自我鉴定范文
2013/12/19 职场文书
公司年会搞笑主持词
2014/03/24 职场文书
好好学习保证书
2015/02/26 职场文书
物业工程部经理岗位职责
2015/04/09 职场文书