Vue學(xué)習(xí)筆記進(jìn)階篇之過渡狀態(tài)詳解
這兩天學(xué)習(xí)了Vue.js 感覺渡系統(tǒng)這個(gè)地方知識點(diǎn)挺多的,而且很重要,所以,今天添加一點(diǎn)小筆記。
Vue 的過渡系統(tǒng)提供了非常多簡單的方法設(shè)置進(jìn)入、離開和列表的動效。那么對于數(shù)據(jù)元素本身的動效呢,比如:
- 數(shù)字和運(yùn)算
- 顏色的顯示
- SVG 節(jié)點(diǎn)的位置
- 元素的大小和其他的屬性
所有的原始數(shù)字都被事先存儲起來,可以直接轉(zhuǎn)換到數(shù)字。做到這一步,我們就可以結(jié)合 Vue 的響應(yīng)式和組件系統(tǒng),使用第三方庫來實(shí)現(xiàn)切換元素的過渡狀態(tài)。
狀態(tài)動畫和watcher
通過 watcher 我們能監(jiān)聽到任何數(shù)值屬性的數(shù)值更新。可能聽起來很抽象,所以讓我們先來看看使用 Tweenjs 一個(gè)例子。
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()
}
}
})
運(yùn)行結(jié)果:

當(dāng)你把數(shù)值更新時(shí),就會觸發(fā)動畫。這個(gè)是一個(gè)不錯的演示,但是對于不能直接像數(shù)字一樣存儲的值,比如 CSS 中的 color 的值,通過下面的例子我們來通過 Color.js 實(shí)現(xiàn)一個(gè)例子。
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 = ''
}
}
})
運(yùn)行結(jié)果:

通過組件組織過渡
管理太多的狀態(tài)轉(zhuǎn)換會很快的增加 Vue 實(shí)例或者組件的復(fù)雜性,幸好很多的動畫可以提取到專用的子組件。
我們來將之前的示例改寫一下:
<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
}
}
})
運(yùn)行結(jié)果:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
VUE渲染后端返回含有script標(biāo)簽的html字符串示例
今天小編就為大家分享 一篇VUE渲染后端返回含有script標(biāo)簽的html字符串示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10
vue中el-table和jsplumb實(shí)現(xiàn)連線功能
本文主要介紹了el-table和jsplumb實(shí)現(xiàn)連線功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
VUE實(shí)現(xiàn)表單元素雙向綁定(總結(jié))
本篇文章主要介紹了VUE實(shí)現(xiàn)表單元素雙向綁定(總結(jié)) ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
Vue3.0利用vue-grid-layout插件實(shí)現(xiàn)拖拽布局
這篇文章主要介紹了Vue3.0利用vue-grid-layout插件實(shí)現(xiàn)拖拽布局,工作中難免遇到需要對頁面布局進(jìn)行拖拽然后改變布局,保存布局,下面文章就圍繞Vue3.0利用vue-grid-layout插件實(shí)現(xiàn)拖拽布局的相關(guān)資料展開詳細(xì)內(nèi)容,需要的朋友可以參考一下2021-11-11
Vue表單綁定的實(shí)例代碼(單選按鈕,選擇框(單選時(shí),多選時(shí),用 v-for 渲染的動態(tài)選項(xiàng))
本文通過實(shí)例代碼給大家介紹了Vue表單綁定(單選按鈕,選擇框(單選時(shí),多選時(shí),用 v-for 渲染的動態(tài)選項(xiàng))的相關(guān)知識,非常不錯,具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-05-05

