劃重點
- 動畫的幾個週期:
- 開始階段
- v-enter:開始動畫前 (這是一個時間點)
- v-enter-active:執行動畫中…
- v-enter-to:開始動畫執行後 (這是一個時間點)
- 離開階段
- v-leave:離開動畫前 (這是一個時間點)
- v-leave-active:離開動畫的過程中…
- v-leave-to:離開動畫之後,離開的終止狀態 這個時候元素動畫已經結束了 (這是一個時間點)
- 開始階段
螞蟻上樹
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.6.10.js"></script>
<style>
/*
動畫的幾個週期:
開始階段:
v-enter :開始動畫前 (這是一個時間點)
v-enter-active: 執行動畫中...
v-enter-to:開始動畫執行後 (這是一個時間點)
離開階段:
v-leave:離開動畫前 (這是一個時間點)
v-leave-active: 離開動畫的過程中...
v-leave-to: 離開動畫之後,離開的終止狀態 這個時候元素動畫已經結束了 (這是一個時間點)
*/
.v-enter,
.v-leave-to {
opacity: 0;
transform: translateX(10rem);
transform: rotate(7deg);
}
/*
自定義 v-前綴
transition標籤中的name就是對應的:其前綴
*/
.my-enter-active,
.my-leave-active {
transition: all 2s ease ;
}
.my-enter,
.my-leave-to {
opacity: 0;
transform: translateY(199px);
}
</style>
</head>
<body>
<div id="app">
<input type="button" value="toggle" @click="flag=!flag">
<transition>
<h3 v-if="flag">這是一個H3</h3>
</transition>
<hr>
<input type="button" value="toggle2" @click="flag2=!flag2">
<transition name="my">
<h6 v-if="flag2"> 這是一個H6 </h6>
</transition>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
flag: false,
flag2:false
},
methods: {
}
})
</script>
</body>
</html>
動畫:點擊後“這是一個H6”文本開始由底部慢慢移動到上面顯示出來