全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

这两天学习了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()
    }
  }
})

运行结果:

当你把数值更新时,就会触发动画。这个是一个不错的演示,但是对于不能直接像数字一样存储的值,比如 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 实例或者组件的复杂性,幸好很多的动画可以提取到专用的子组件。

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

<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  # 过渡状态  # 过渡  # Vue.2.0.5过渡效果使用技巧  # 详解Vue中添加过渡效果  # 基于Vue过渡状态实例讲解  # 是一个  # 就会  # 太多  # 让我们  # 其他的  # 很重要  # 可以直接  # 你把  # 第三方  # 听起来  # 这两天  # 来实现  # 先来  # 大家多多  # 就可以  # 挺多  # 这一步  # xhtml  # gt  # id 


相关文章: 定制建站方案优化指南:企业官网开发与建站费用解析  c# 在ASP.NET Core中管理和取消后台任务  如何选择高性价比服务器搭建个人网站?  如何在万网自助建站平台快速创建网站?  建站与域名管理如何高效结合?  建站之星图片链接生成指南:自助建站与智能设计教程  电商网站制作价格怎么算,网上拍卖流程以及规则?  c# 在高并发场景下,委托和接口调用的性能对比  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何通过主机屋免费建站教程十分钟搭建网站?  如何在腾讯云服务器快速搭建个人网站?  简历在线制作网站免费版,如何创建个人简历?  如何通过万网虚拟主机快速搭建网站?  定制建站策划方案_专业建站与网站建设方案一站式指南  娃派WAP自助建站:免费模板+移动优化,快速打造专业网站  建站之星2.7模板:企业网站建设与h5定制设计专题  北京企业网站设计制作公司,北京铁路集团官方网站?  合肥做个网站多少钱,合肥本地有没有比较靠谱的交友平台?  测试制作网站有哪些,测试性取向的权威测试或者网站?  高端企业智能建站程序:SEO优化与响应式模板定制开发  临沂网站制作企业,临沂第三中学官方网站?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  公司网站制作需要多少钱,找人做公司网站需要多少钱?  建站之星北京办公室:智能建站系统与小程序生成方案解析  网站设计制作公司地址,网站建设比较好的公司都有哪些?  广州商城建站系统开发成本与周期如何控制?  建站之星手机一键生成:多端自适应+小程序开发快速建站指南  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  建站之星后台密码遗忘?如何快速找回?  广州顶尖建站服务:企业官网建设与SEO优化一体化方案  宝塔新建站点为何无法访问?如何排查?    网站制作培训多少钱一个月,网站优化seo培训课程有哪些?  内部网站制作流程,如何建立公司内部网站?  建站主机无法访问?如何排查域名与服务器问题  C++用Dijkstra(迪杰斯特拉)算法求最短路径  如何通过智能用户系统一键生成高效建站方案?  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  如何通过西部建站助手安装IIS服务器?  建站之星展会模版如何一键下载生成?  安云自助建站系统如何快速提升SEO排名?  Python lxml的etree和ElementTree有什么区别  MySQL查询结果复制到新表的方法(更新、插入)  建站主机数据库如何配置才能提升网站性能?  深圳网站制作平台,深圳市做网站好的公司有哪些?  网页设计与网站制作内容,怎样注册网站?  建站之星好吗?新手能否轻松上手建站?  c++怎么用jemalloc c++替换默认内存分配器【性能】  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  建站之星如何快速生成多端适配网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。