Vue的过渡是一种技术,它可以让你在Vue应用程序中创建动画和过渡效果。它可以帮助你在不同的状态之间创建平滑的过渡,从而使你的应用程序看起来更加流畅。
Vue的过渡是基于CSS3实现的,它可以让你使用CSS3中的transition属性来创建动画效果。例如,你可以使用transition-property来设置要过渡的CSS属性,transition-duration来设置过渡时间,transition-timing-function来设置过渡速度,以及transition-delay来设置过渡延时。
Vue也允许你使用JavaScript代码来创建动画效果。例如,你可以使用Vue.js中的v-if、v-show、v-for、v-on、v-bind或者其他相关API来定义要执行的动作或者要显示/隐藏/重复/监听/绑定的内容。
此外,Vue也允许你使用JavaScript代码与CSS3 transition API配合使用,从而创造出复杂而有意义的动画效果。例如:
<div v-if="show" transition="fade"> <h1>Hello World!</h1> </div> // JavaScript code new Vue({ el: '#app', data: { show: true }, transitions: { fade: { enterClass: 'fadeIn', leaveClass: 'fadeOut' } } })
上面代码中,我们使用了v-if、transition API 和JavaScript代码配合使用,当show为true时会显示“Hello World”文字并且会有一个fadeIn效果出现。当show为false时会隐藏“Hello World”文字并且会有一个fadeOut效果出现。
总之,Vue.js 的过渡是一项强大而有意义的工具,它可以帮助开发者在不同的阶段之间创造出流畅而有意义的动画效果。
Vue 的过渡系统提供了非常多简单的方法设置进入、离开和列表的动效。那么对于数据元素本身的动效呢,比如:
这些数据要么本身就以数值形式存储,要么可以转换为数值。有了这些数值后,我们就可以结合 Vue 的响应性和组件系统,使用第三方库来实现切换元素的过渡状态。
通过侦听器我们能监听到任何数值 property 的数值更新。可能听起来很抽象,所以让我们先来看看使用 GreenSock 一个例子:
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.2.4/gsap.min.js" rel="external nofollow" rel="external nofollow" ></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")
点击此处实现
更新数字时,更改将在输入下方设置动画。
就像 Vue 的过渡组件一样,数据背后状态过渡会实时更新,这对于原型设计十分有用。当你修改一些变量,即使是一个简单的 SVG 多边形也可实现很多难以想象的效果。
点击此处实现
管理太多的状态过渡会很快的增加组件实例复杂性,幸好很多的动画可以提取到专用的子组件。我们来将之前的示例改写一下:
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.2.4/gsap.min.js" rel="external nofollow" rel="external nofollow" ></script>
<div id="app">
<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>
</div>
const app = Vue.createApp({
data() {
return {
firstNumber: 20,
secondNumber: 40
}
},
computed: {
result() {
return this.firstNumber + this.secondNumber
}
}
})
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)
}
})
app.mount("#app")
点击此处实现
我们能在组件中结合使用这一节讲到各种过渡策略和 Vue 内建的过渡系统。总之,对于完成各种过渡动效几乎没有阻碍。
你可以看到我们如何使用它进行数据可视化,物理效果,角色动画和交互,天空是极限。
只要一个动画,就可以带来生命。不幸的是,当设计师创建图标、logo 和吉祥物的时候,他们交付的通常都是图片或静态的 SVG。所以,虽然 GitHub 的章鱼猫、Twitter 的小鸟以及其它许多 logo 类似于生灵,它们看上去实际上并不是活着的。
Vue 可以帮到你。因为 SVG 的本质是数据,我们只需要这些动物兴奋、思考或警戒的样例。然后 Vue 就可以辅助完成这几种状态之间的过渡动画,来制作你的欢迎页面、加载指示、以及更加带有情感的提示。
Sarah Drasner 展示了下面这个 demo,这个 demo 结合了时间和交互相关的状态改变:
点击此处实现
Vue 推荐在绝大多数情况下使用模板来创建你的 HTML。然而在一些场景中,你真的需要 JavaScript 的完全编程的能力。这时你可以用...
本节使用单文件组件代码示例的语法本指南假定你已经阅读了组合式 API 简介和响应性原理。如果你不熟悉组合式 API,请先阅读这篇...
本指南假定你已经阅读了 Provide / Inject、组合式 API 介绍和响应性基础。如果你不熟悉组合式 API,请先阅读这篇文章。我们也可...
为了学习如何更好地使用 Vue,不需要阅读本页,但是它提供了更多信息,如果你想知道渲染在背后是如何工作的。#虚拟 DOM现在我们...
#介绍当构建可靠的应用时,测试在个人或团队构建新特性、重构代码、修复 bug 等工作中扮演了关键的角色。尽管测试的流派有很多,...