當只用 JavaScript 過渡的時候,在 enter
和 leave
中必須使用 done
進行回調。否則,它們將被同步調用,過渡會立即完成。
推薦對於僅使用 JavaScript 過渡的元素添加 v-bind:css="false"
,Vue 會跳過 CSS 的檢測。這也可以避免過渡過程中 CSS 的影響。
一個js動畫的簡單 例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue 動畫</title>
<script src="./vue.js"></script>
<link href="https://cdn.jsdelivr.net/npm/[email protected]" rel="stylesheet" type="text/css">
<!--Velocity 和 jQuery.animate 的工作方式類似,也是用來實現 JavaScript 動畫的一個很棒的選擇-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
<style>
</style>
</head>
<body>
<div id="root">
<transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
<h1 v-show="show">Hello World</h1>
</transition>
<button @click="handleClick">toggle</button>
</div>
<script>
var app = new Vue({
el: " #root ",
data: {
show: true
},
methods: {
handleClick: function() {
this.show = !this.show;
},
handleBeforeEnter: function(el) { //el指動畫包裹的div標籤
console.log('beforeEnter');
el.style.color = 'red';
},
handlerEnter: function(el, done) { //done是回調函數
setTimeout(() => { //2s green
el.style.color = "green"
}, 2000)
setTimeout(() => { //再2s後 black
el.style.color = "black"
}, 4000)
},
handleAfterEnter: function(el) {
el.style.color = "#000"
},
}
})
</script>
</body>
</html>
幾個鉤子名稱:
before-enter,enter,after-enter,before-leave,leave,after-leave
一使用 Velocity.js 的簡單例子:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Vue 動畫</title>
<script src="./vue.js"></script>
<link href="https://cdn.jsdelivr.net/npm/[email protected]" rel="stylesheet" type="text/css">
<!--Velocity 和 jQuery.animate 的工作方式類似,也是用來實現 JavaScript 動畫的一個很棒的選擇-->
<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
<style>
</style>
</head>
<body>
<div id="root">
<transition name="fade" @before-enter="handleBeforeEnter" @enter="handlerEnter" @after-enter="handleAfterEnter">
<h1 v-show="show">Hello World</h1>
</transition>
<button @click="handleClick">toggle</button>
</div>
<script>
var app = new Vue({
el: " #root ",
data: {
show: true
},
methods: {
handleClick: function() {
this.show = !this.show;
},
handleBeforeEnter: function(el) { //el指動畫包裹的div標籤
el.style.opacity = 0;
},
handlerEnter: function(el, done) { //done是回調函數
Velocity(el, {
opacity: 1
}, { //complete:done 當執行動畫之後,done回調會被執行
duration: 1000,
complete: done
})
},
handleAfterEnter: function(el) {
alert("動畫結束")
},
}
})
</script>
</body>
</html>