隨著網路科技的不斷發展,越來越多的網站和應用程式需要呈現出酷炫的動畫效果以提高使用者體驗。 Vue3作為現代化的JavaScript框架,為開發者提供了許多優秀的工具包,其中就包含動畫函數。本文將詳細介紹Vue3中的動畫函數的應用和實作方法,以及如何實現酷炫的動畫效果。
Vue3透過Composition API提供了強大的動畫函數庫,其中包含:
:過渡函數
:動畫函數
:緩動函數
##:彈簧函數
是Vue3中的過渡函數,用於在兩個狀態之間進行過渡,例如從顯示到隱藏、從上滑入到下滑出等。其基本用法如下:
import { useTransition } from 'vue' const transitions = useTransition(show, { // 定义三个阶段的动画 enter: '', leave: '', appear: '' })
是一個布林類型的值,表示目前狀態是否應該呈現。
enter 和
appear簡單範例:
<template> <div class="container"> <button @click="toggle">Toggle</button> <transition appear v-for="msg in msgs" :key="msg.id" :css="false" :enter-class="'animate__animated animate__fadeInDown'" :leave-class="'animate__animated animate__fadeOutUp'" > <div class="alert" :class="'alert-' + msg.type"> {{ msg.message }} </div> </transition> </div> </template> <script> import { reactive, toRefs, ref, useTransition } from 'vue'; export default { setup() { const data = reactive({ msgs: [] }) const toggle = () => { data.msgs.unshift({ id: Math.random(), type: 'success', message: '这是一条消息' }) } const transitions = useTransition(data.msgs, { enterActiveClass: 'animate__animated animate__fadeInDown', leaveActiveClass: 'animate__animated animate__fadeOutUp' }) return { ...toRefs(data), transitions, toggle } } } </script>
值的改變時,就會透過過渡函數來顯示或隱藏提示方塊區域。在這個例子中,我們使用了animate.css這個函式庫來實現動畫效果。
useAnimation
與過渡函數不同,動畫函數可以自訂各種半徑,例如旋轉、縮放等。使用
可以定義各種動畫效果,它接受一個函數作為參數,該函數包含以下幾個參數:
to
duration
delay
ease
:緩動函數
一個簡單範例:
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:javascript;toolbar:false;'>import { useAnimation } from 'vue'
const animations = useAnimation(() => ({
top: 0,
left: 0,
backgroundColor: 'red',
width: '100px',
height: '100px',
translateY: 0,
rotate: '0deg'
}), {
from: {
top: '100px',
left: '100px',
backgroundColor: 'blue',
width: '50px',
height: '50px',
translateY: '200px',
rotate: '-90deg'
},
to: {
top: '200px',
left: '200px',
backgroundColor: 'black',
width: '200px',
height: '200px',
translateY: '0px',
rotate: '360deg'
},
duration: 3000,
delay: 1000,
ease: 'ease'
})</pre><div class="contentsignin">登入後複製</div></div>
這個範例定義一個動畫函數,將initial
狀態從一個小藍色正方形轉換為一個大黑色正方形,同時建立更改它們的屬性的動畫。 值得注意的是,由於動畫是在
<template> <div :style="animations"></div> </template> <script> import { useAnimation } from 'vue'; export default { setup() { const animations = useAnimation(() => ({ top: 0, left: 0, backgroundColor: 'red', width: '100px', height: '100px', translateY: 0, rotate: '0deg' }), { from: { top: '100px', left: '100px', backgroundColor: 'blue', width: '50px', height: '50px', translateY: '200px', rotate: '-90deg' }, to: { top: '200px', left: '200px', backgroundColor: 'black', width: '200px', height: '200px', translateY: '0px', rotate: '360deg' }, duration: 3000, delay: 1000, ease: 'ease' }) return { animations } } } </script>
在模板中需要動畫的屬性值可以傳遞到
:styleuseTween
#緩動函數不僅可以有動畫效果,還可以讓動畫更自然。 Vue3提供了 useTween
函數,用於創建彈性、阻尼、彈簧等緩動效果。基本用法如下:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:javascript;toolbar:false;'>import { useTween } from 'vue'
const tween = useTween(0, 100, {
duration: 1000,
delay: 0,
ease: 'easeInQuad',
onComplete: () => {
console.log('Completed')
}
})</pre><div class="contentsignin">登入後複製</div></div>
此範例將在指定時間內將值從0轉換為100,使用
的例子:<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:html;toolbar:false;'><template>
<div>
<div :style="{ transform: 'translateX(' + xValue + 'px)' }">{{ xValue }}</div>
<button @click="move">Move</button>
</div>
</template>
<script>
import { ref, useTween } from 'vue';
export default {
setup() {
const xValue = ref(0)
const move = () => {
useTween(0, 300, {
duration: 1000,
ease: 'easeOutElastic',
onUpdate: (value) => {
xValue.value = value
}
})
}
return {
xValue,
move
}
}
}
</script></pre><div class="contentsignin">登入後複製</div></div>
在這個例子中,我們用
import { useSpring } from 'vue' const spring = useSpring({ from: { opacity: 0, transform: 'translateX(-100px)' }, to: { opacity: 1, transform: 'translateX(0px)' }, config: { tension: 120, friction: 14, mass: 5 } })
<template> <div :style="spring"> <h1>这是一个标题</h1> <p>这是一段内容</p> </div> </template> <script> import { useSpring } from 'vue'; export default { setup() { const spring = useSpring({ from: { opacity: 0, transform: 'translateX(-100px)' }, to: { opacity: 1, transform: 'translateX(0px)' }, config: { tension: 120, friction: 14, mass: 5 } }) return { spring } } } </script>
以上是Vue3中的動畫函數詳解:實現酷炫的動畫效果的應用的詳細內容。更多資訊請關注PHP中文網其他相關文章!