Vue学习笔记进阶篇之过渡状态详解


Posted in Javascript onJuly 14, 2017

这两天学习了Vue.js 感觉渡系统这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。

Vue 的过渡系统提供了非常多简单的方法设置进入、离开和列表的动效。那么对于数据元素本身的动效呢,比如:

  1. 数字和运算
  2. 颜色的显示
  3. SVG 节点的位置
  4. 元素的大小和其他的属性

所有的原始数字都被事先存储起来,可以直接转换到数字。做到这一步,我们就可以结合 Vue 的响应式和组件系统,使用第三方库来实现切换元素的过渡状态。

状态动画和watcher

通过 watcher 我们能监听到任何数值属性的数值更新。可能听起来很抽象,所以让我们先来看看使用 Tweenjs 一个例子。

Js代码中引入:

<script src="https://unpkg.com/tween.js@16.3.4"></script>

示例代码:

<div id="app1">
  <input v-model.number="number" type="number" step="20">
  <p>{{animateNumber}}</p>
</div>
var app1 = new Vue({
  el:'#app1',
  data:{
    number:0,
    animateNumber:0
  },
  watch:{
    number:function (newVal, oldVal) {
      var vm = this
      function animate() {
        if (TWEEN.update()){
          requestAnimationFrame(animate)
        }
      }

      new TWEEN.Tween({tweeningNumber:oldVal})
        .easing(TWEEN.Easing.Quadratic.Out)
        .to({tweeningNumber:newVal}, 500)
        .onUpdate(function () {
          vm.animateNumber = this.tweeningNumber.toFixed(0)
        })
        .onComplete(function () {
          cancelAnimationFrame(animate)
        })
        .start()
      animate()
    }
  }
})

运行结果:

Vue学习笔记进阶篇之过渡状态详解

当你把数值更新时,就会触发动画。这个是一个不错的演示,但是对于不能直接像数字一样存储的值,比如 CSS 中的 color 的值,通过下面的例子我们来通过 Color.js 实现一个例子。

js需要添加以下引用:

<script src="https://unpkg.com/tween.js@16.3.4"></script>
<script src="https://unpkg.com/color-js@1.0.3/color.js"></script>

示例代码:

<div id="app-color">
  <input v-model="colorQuery" @keyup.enter="updateColor" placeholder="Enter a color">
  <button @click="updateColor">Update</button>
  <p>Preview:</p>
  <span :style="{backgroundColor:tweenedCSSColor}" class="color-preview">

  </span>
  <p>{{tweenedCSSColor}}</p>
</div>
var Color = net.brehaut.Color
new Vue({
  el:'#app-color',
  data:{
    colorQuery:'',
    color:{
      red:0,
      green:0,
      blue:0,
      alpha:1
    },
    tweenedColor:{}
  },
  created:function () {
    this.tweenedColor = Object.assign({}, this.color)
  },
  watch:{
    color:function () {
      function animate() {
        if (TWEEN.update()){
          requestAnimationFrame(animate)
        }
      }
      new TWEEN.Tween(this.tweenedColor)
        .to(this.color, 750)
        .start()
      animate()
    }
  },
  computed:{
    tweenedCSSColor:function () {
      return new Color({
        red:this.tweenedColor.red,
        green:this.tweenedColor.green,
        blue:this.tweenedColor.blue,
        alpha:this.tweenedColor.alpha
      }).toCSS()
    }
  },
  methods:{
    updateColor:function () {
      this.color = new Color(this.colorQuery).toRGB()
      this.colorQuery = ''
    }
  }
})

运行结果:

Vue学习笔记进阶篇之过渡状态详解

通过组件组织过渡

管理太多的状态转换会很快的增加 Vue 实例或者组件的复杂性,幸好很多的动画可以提取到专用的子组件。

我们来将之前的示例改写一下:

<div id="app">
  <input v-model.number="firstNumber" type="number" step="20"> +
  <input v-model.number="secondNumber" type="number" step="20"> =
  {{result}}
  <p>
    <animate-integer :value="firstNumber"></animate-integer> +
    <animate-integer :value="secondNumber"></animate-integer> =
    <animate-integer :value="result"></animate-integer>
  </p>
</div>
Vue.component('animate-integer',{
  template:'<span>{{tweeningValue}}</span>',
  props:{
    value:{
      type:Number,
      required:true
    }
  },
  data:function () {
    return {tweeningValue:0}
  },
  mounted:function () {
    this.tween(0, this.value)
  },
  watch:{
    value:function (newVal, oldVal) {
      this.tween(oldVal, newVal)
    }
  },
  methods:{
    tween:function (startValue, endValue) {
      var vm = this
      function animate() {
        if(TWEEN.update()){
        requestAnimationFrame(animate)
        }
      }
      new TWEEN.Tween({tweeningValue:startValue})
        .to({tweeningValue:endValue}, 500)
        .onUpdate(function () {
          vm.tweeningValue = this.tweeningValue.toFixed(0)
        }).start()
      animate()
    }
  }
})

new Vue({
  el:'#app',
  data:{
    firstNumber:20,
    secondNumber:40
  },
  computed:{
    result:function () {
      return this.firstNumber + this.secondNumber
    }
  }
})

运行结果:

Vue学习笔记进阶篇之过渡状态详解

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

Javascript 相关文章推荐
可输入的下拉框
Jun 19 Javascript
javascript实现文字图片上下滚动的具体实例
Jun 28 Javascript
IE6-8中Date不支持toISOString的修复方法
May 04 Javascript
JS实现pasteHTML兼容ie,firefox,chrome的方法
Jun 22 Javascript
JQueryEasyUI框架下的combobox的取值和绑定的方法
Jan 22 Javascript
jquery ajax加载数据前台渲染方式 不用for遍历的方法
Aug 09 jQuery
微信小程序swiper实现滑动放大缩小效果
Nov 15 Javascript
深入koa-bodyparser原理解析
Jan 16 Javascript
js中实例与对象的区别讲解
Jan 21 Javascript
中高级前端必须了解的JS中的内存管理(推荐)
Jul 04 Javascript
javascript实现超好看的3D烟花特效
Jan 01 Javascript
vue @click.native 绑定原生点击事件
Apr 22 Vue.js
微信小程序开发之animation循环动画实现的让云朵飘效果
Jul 14 #Javascript
使用OPENLAYERS3实现点选的方法
Sep 24 #Javascript
vue component组件使用方法详解
Jul 14 #Javascript
vue-cli单页应用改成多页应用配置详解
Jul 14 #Javascript
Vue filters过滤器的使用方法
Jul 14 #Javascript
vue.js如何更改默认端口号8080为指定端口的方法
Jul 14 #Javascript
Vue computed计算属性的使用方法
Jul 14 #Javascript
You might like
星际争霸秘籍
2020/03/04 星际争霸
PHP遍历目录并返回统计目录大小
2014/06/09 PHP
PHP函数实现分页含文本分页和数字分页
2014/10/23 PHP
什么是PEAR?什么是PECL?PHP中两个容易混淆的概念解释
2015/07/01 PHP
MyEclipse取消验证Js的两种方法
2013/11/14 Javascript
js检测网络是否具体连接功能的代码
2014/05/23 Javascript
javascript精确统计网站访问量实例代码
2015/12/19 Javascript
Bootstrap安装环境配置教程分享
2016/05/27 Javascript
javascript类型系统_正则表达式RegExp类型详解
2016/06/24 Javascript
15位和18位身份证JS校验的简单实例
2016/07/18 Javascript
js鼠标移动时禁止选中文字
2017/02/19 Javascript
ReactNative中使用Redux架构总结
2017/12/15 Javascript
JavaScript基于面向对象实现的猜拳游戏
2018/01/03 Javascript
vue插件draggable实现拖拽移动图片顺序
2018/12/01 Javascript
iview的table组件自带的过滤器实现
2019/07/12 Javascript
js 执行上下文和作用域的相关总结
2021/02/08 Javascript
Python实现简单拆分PDF文件的方法
2015/07/30 Python
Python制作钉钉加密/解密工具
2016/12/07 Python
Python输出带颜色的字符串实例
2017/10/10 Python
python计算两个数的百分比方法
2018/06/29 Python
Python通过文本和图片生成词云图
2020/05/21 Python
Python模拟登入的N种方式(建议收藏)
2020/05/31 Python
css3中background新增的4个新的相关属性用法介绍
2013/09/26 HTML / CSS
html5+CSS3+JS实现七夕言情功能代码
2017/08/28 HTML / CSS
鲜为人知的HTML5语音合成功能
2019/05/17 HTML / CSS
迪梵英国官方网站:Darphin英国
2017/12/06 全球购物
瑞士灯具购物网站:Lampenwelt.ch
2018/07/08 全球购物
澳大利亚儿童鞋在线:The Trybe
2019/07/16 全球购物
中层干部岗位职责
2013/12/18 职场文书
村创先争优活动总结
2014/08/28 职场文书
学生偷窃检讨书
2014/09/25 职场文书
党员对十八届四中全会的期盼思想汇报范文
2014/10/17 职场文书
2014年党支部工作总结
2014/11/13 职场文书
2015年毕业生自荐信范文
2015/03/24 职场文书
护理自荐信
2019/05/14 职场文书
PYTHON使用Matplotlib去实现各种条形图的绘制
2022/03/22 Python