Vue動畫效果


1.哪些元素/那些組件適合在那些條件下實現動畫效果

  • 條件渲染 (使用 v-if)
  • 條件展示 (使用 v-show)
  • 動態組件
  • 組件根節點

簡單經典例子:(文字隱藏到顯示效果)

<div>
  <button @click="show = !show">show toggle</button> <transition name="fade"> //fade 自定義名稱 <p v-if="show">hello</p> </transition> </div> <style> .fade-enter-active{ transition: opacity .5s; //類名:隱藏到顯示過程所需要的時間 } .fade-enter { // 類名:初始化狀態 opacity: 0; } </style> 復制代碼

自己畫了一個過渡動畫生命周期,表示:動畫開始,過程,結束,類名生效和失效

 

image.png

 

隱藏到顯示,顯示到隱藏過程

 

image.png

 

css動畫

<div>
  <button @click="show = !show">show toggle</button> <transition name="fade"> //fade 自定義名稱 <p v-if="show">hello</p> </transition> </div> <style> .fade-enter-active { //類名:隱藏到顯示過程所需要的時間 animation: bounce-in .5s; } .fade-leave-active { //類名:顯示到隱藏過程所需要的時間 animation: bounce-in .5s reverse; //reverse表示和隱藏到顯示動畫相反 } @keyframes bounce-in { 0% { transform: scale(0); } 50% { transform: scale(1.5); } 100% { transform: scale(1); } } </style> 復制代碼

我們也可以自定義類名

<div>
  <button @click="show = !show">show toggle</button> <transition enter-class="fadeEnter" enter-active-class="fadeActive" > //fade 自定義名稱 <p v-if="show">hello</p> </transition> </div> <style> .fadeActive{ transition: opacity .5s; //類名:隱藏到顯示過程所需要的時間 } .fadeEnter { // 類名:初始化狀態 opacity: 0; } </style> 復制代碼

學到這里,我們其實也可以可以引用第三方庫來實現這效果,Animate.css

// 在index.html文件下引入Animate.css
<link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css"> // 在組件內 <div> <button @click="show = !show">show toggle</button> <transition enter-active-class="animated tada" leave-active-class="animated bounceOutRight" > <p v-if="show">hello</p> </transition> </div>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM