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

Vue 的过渡系统提供了非常多简单的方法设置进入、离开和列表的动效。那么对于数据元素本身的动效呢,比如:
所有的原始数字都被事先存储起来,可以直接转换到数字。做到这一步,我们就可以结合 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小时内与您取得联系。