Vue的过渡系统提供了非常多简单的方法设置进入、离开和列表的动效。那么对于数据元素本身的动效呢?比如:
- 数字和运算
- 颜色的显示
- SVG节点的位置
- 元素的大小和其他的property 这些数据要么本身就以数值形式存储,要么可以转换为数值。有了这些数值后,我们就可以结合Vue的响应性和组件系统,使用第三方库来实现切换元素的过渡效果。
1.状态动画与侦听器
通过侦听器我们能监听到任何数值property的数值更新。可能听起来很抽象,所以可以先看看使用GreenSock的一个例子:
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.2.4/gsap.min.js"></script>
<div id="animated-number-demo">
<input v-model.number="number" type="number" step="20" />
<p>{{ animatedNumber }}</p>
</div>
const Demo = {
data() {
return {
number: 0,
tweenedNumber: 0
}
},
computed: {
animatedNumber() {
return this.tweenedNumber.toFixed(0)
}
},
watch: {
number(newValue) {
gsap.to(this.$data, { duration: 0.5, tweenedNumber: newValue })
}
}
}
Vue.createApp(Demo).mount('#animated-number-demo')
更新数字时,输入框下方会对更改设置动画效果。
2.动态状态过渡
就像Vue的过渡组件一样,数据背后状态过渡会实时更新,这对于原型设计十分有用。当你修改一些变量,即使是一个简单的SVG多边形也可实现很多难以想象的效果。
3.把过渡放到组件里
管理太多的状态过渡会迅速增加组件实例的复杂度,幸好很多的动画可以提取到专用的子组件中。
<input v-model.number="firstNumber" type="number" step="20"> +
<input v-model.number="secondNumber" type="number" step="20"> =
{{ result }}
<p>
<animated-integer :value="firstNumber"></animated-integer> +
<animated-integer :value="secondNumber"></animated-integer> =
<animated-integer :value="result"></animated-integer>
</p>
app.component('animated-integer', {
template: '<span>{{ fullValue }}</span>',
props: {
value: {
type: Number,
required: true
}
},
data() {
return {
tweeningValue: 0
}
},
computed: {
fullValue() {
return Math.floor(this.tweeningValue)
}
},
methods: {
tween(newValue, oldValue) {
gsap.to(this.$data, {
duration: 0.5,
tweeningValue: newValue,
ease: 'sine'
});
}
},
watch: {
value(newValue, oldValue) {
this.tween(newValue, oldValue)
}
},
mounted() {
this.tween(this.value, 0)
},
})
我们能在组件中结合使用各种过渡策略和Vue内建的过渡系统,对于完成各种过渡动效几乎没有阻碍。 我们使用它进行数据可视化、物理效果、角色动画和交互,一切都没有限制。
4.赋予设计以生命
动画效果可以栩栩如生。不幸的是,设计师创建图标、logo和吉祥物的时候,他们交付的通常都是图片或静态的SVG。所以虽然许多logo类似于生灵,它们看上去实际上并不是活着的。 Vue可以帮到你,因为SVG的本质是数据,只需要准备好这些生物兴奋、思考或警戒的样例。Vue就可以辅助完成这几种状态之间的过渡动画。