中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue實現過渡效果的示例分析

發布時間:2021-03-22 11:46:02 來源:億速云 閱讀:140 作者:小新 欄目:web開發

小編給大家分享一下Vue實現過渡效果的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

以一個toggle按鈕控制p元素顯隱為例,如果不使用過渡效果,則如下所示

<div id="demo">
 <button v-on:click="show = !show">Toggle</button>
 <p v-if="show">藍色理想</p>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true
 }
})
</script>

如果要為此加入過渡效果,則需要使用過渡組件transition 

過渡組件

Vue提供了transition的封裝組件,下面代碼中,該過渡組件的名稱為'fade'

 <transition name="fade">
  <p v-if="show">藍色理想</p>
 </transition>

當插入或刪除包含在transition組件中的元素時,Vue會自動嗅探目標元素是否應用了 CSS 過渡或動畫,如果是,在恰當的時機添加/刪除 CSS 類名 

過渡類名

總共有6個(CSS)類名在enter/leave的過渡中切換

v-enter

定義進入過渡的開始狀態。在元素被插入時生效,在下一個幀移除

v-enter-active

定義過渡的狀態。在元素整個過渡過程中作用,在元素被插入時生效,在 transition 或 animation 完成之后移除。 這個類可以被用來定義過渡的過程時間,延遲和曲線函數

v-enter-to

定義進入過渡的結束狀態。在元素被插入一幀后生效(與此同時 v-enter 被刪除),在  transition 或 animation 完成之后移除

v-leave

定義離開過渡的開始狀態。在離開過渡被觸發時生效,在下一個幀移除

v-leave-active

定義過渡的狀態。在元素整個過渡過程中作用,在離開過渡被觸發后立即生效,在 transition 或 animation 完成之后移除。 這個類可以被用來定義過渡的過程時間,延遲和曲線函數

v-leave-to

定義離開過渡的結束狀態。在離開過渡被觸發一幀后生效(與此同時 v-leave 被刪除),在 transition 或 animation 完成之后移除

對于這些在 enter/leave 過渡中切換的類名,v- 是這些類名的前綴,表示過渡組件的名稱。比如,如果使用 <transition name="my-transition"> ,則 v-enter替換為 my-transition-enter

transition

常用的Vue過渡效果都是使用CSS過渡transition,下面增加一個enter時透明度變化,leave時位移變化的效果

<style>
.fade-enter{
 opacity:0;
}
.fade-enter-active{
 transition:opacity .5s;
}
.fade-leave-active{
 transition:transform .5s;
}
.fade-leave-to{
 transform:translateX(10px);
}
</style>
<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="fade">
  <p v-if="show">藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true
 }
})
</script>

animation

CSS動畫animation用法同CSS過渡transition,區別是在動畫中 v-enter 類名在節點插入 DOM 后不會立即刪除,而是在 animationend 事件觸發時刪除

下面例子中,在元素enter和leave時都增加縮放scale效果

<style>
.bounce-enter-active{
 animation:bounce-in .5s;
}
.bounce-leave-active{
 animation:bounce-in .5s reverse;
}
@keyframes bounce-in{
 0%{transform:scale(0);}
 50%{transform:scale(1.5);}
 100%{transform:scale(1);}
}
</style>
<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="bounce">
  <p v-if="show">藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true
 }
})
</script>

同時使用

Vue 為了知道過渡的完成,必須設置相應的事件監聽器。它可以是 transitionend 或 animationend ,這取決于給元素應用的 CSS 規則。如果使用其中任何一種,Vue 能自動識別類型并設置監聽。

但是,在一些場景中,需要給同一個元素同時設置兩種過渡動效,比如 animation 很快的被觸發并完成了,而 transition 效果還沒結束。在這種情況中,就需要使用 type 特性并設置 animation 或 transition 來明確聲明需要 Vue 監聽的類型

<style>
.fade-enter,.fade-leave-to{
 opacity:0;
}
.fade-enter-active,.fade-leave-active{
 transition:opacity 1s;
 animation:bounce-in 5s;
}
@keyframes bounce-in{
 0%{transform:scale(0);}
 50%{transform:scale(1.5);}
 100%{transform:scale(1);}
}
</style>
<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="fade" type="transition">
  <p v-if="show">藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true,
 },
})
</script>

自定義類名

可以通過以下特性來自定義過渡類名

enter-class

enter-active-class

enter-to-class 

leave-class

leave-active-class

leave-to-class 

自定義類名的優先級高于普通的類名,這對于Vue的過渡系統和其他第三方CSS動畫庫,如 Animate.css 結合使用十分有用

<link rel="stylesheet" href="https://unpkg.com/animate.css@3.5.2/animate.min.css" rel="external nofollow" >
<div id="example">
 <button @click="show = !show">
  Toggle render
 </button>
 <transition name="xxx" enter-active-class="animated tada" leave-active-class="animated bounceOutRight">
  <p v-if="show">藍色理想</p>
 </transition>
</div>
<script src="https://www.jb51.com/vue"></script>
<script>
new Vue({
 el: '#example',
 data: {
  show: true
 }
})
</script>

初始渲染過渡

可以通過 appear 特性設置節點的在初始渲染的過渡

<transition appear>
 <!-- ... -->
</transition>

這里默認和進入和離開過渡一樣,同樣也可以自定義 CSS 類名

<transition
 appear
 appear-class="custom-appear-class"
 appear-to-class="custom-appear-to-class" 
 appear-active-class="custom-appear-active-class"
>
 <!-- ... -->
</transition>

下面是一個例子

<style>
.custom-appear-class{
 opacity:0;
 background-color:pink;
 transform:translateX(100px);
} 
.custom-appear-active-class{
 transition: 2s;
}
</style>
<div id="demo">
 <button @click="reset">還原</button>
 <transition appear  appear-class="custom-appear-class"
 appear-to-class="custom-appear-to-class" 
 appear-active-class="custom-appear-active-class">
  <p>藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 methods:{
  reset(){
   history.go();
  }
 }
})
</script>

過渡時間

在很多情況下,Vue可以自動得出過渡效果的完成時機。默認情況下,Vue會等待其在過渡效果的根元素的第一個 transitionend 或 animationend 事件。然而也可以不這樣設定——比如,可以擁有一個精心編排的一序列過渡效果,其中一些嵌套的內部元素相比于過渡效果的根元素有延遲的或更長的過渡效果

在這種情況下可以用<transition>組件上的duration屬性定制一個顯性的過渡效果持續時間 (以毫秒計)

下面的代碼意味著元素在進入enter和離開leave時,持續時間都為1s,而無論在樣式中它們的設置值為多少

<transition :duration="1000">...</transition>

也可以分別定制進入和移出的持續時間

<transition :duration="{ enter: 500, leave: 800 }">...</transition>

比如,下面的代碼中,進入和移出的效果都為animate.css里面的shake效果,但持續時間分別是0.5s和1s

<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition :duration="{ enter: 500, leave: 1000 }" name="xxx" enter-active-class="animated shake" leave-active-class="animated shake">
  <p v-if="show">小火柴的藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true
 }
})
</script>

過渡條件

一般地,在Vue中滿足下列任意一個過渡條件,即可添加過渡效果

條件渲染(使用v-if)

常見的條件是使用條件渲染,使用v-if

<style>
.fade-enter,.fade-leave-to{
 opacity:0;
}
.fade-enter-active,.fade-leave-active{
 transition:opacity 1s;
}
</style>
<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="fade">
  <p v-if="show">藍色理想</p>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 data: {
  show: true
 }
})
</script>

條件展示(使用v-show)

使用條件展示,即使用v-show時,也可以添加過渡效果

<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="fade">
  <p v-show="show">藍色理想</p>
 </transition>
</div>

動態組件

使用is屬性實現的動態組件,可以添加過渡效果

<div id="demo">
 <button v-on:click="show = !show">Toggle</button>  
 <transition name="fade">
  <component :is="view"></component>
 </transition>
</div>
<script>
new Vue({
 el: '#demo',
 components:{
  'home':{template:'<div>藍色理想</div>'}
 },
 data: {
  show: true,
 },
 computed:{
  view(){
   return this.show ? 'home' : '';
  }
 }
})

以上是“Vue實現過渡效果的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

阳西县| 晋中市| 凤冈县| 石楼县| 南召县| 明水县| 满城县| 来安县| 石河子市| 稻城县| 汶上县| 莱州市| 武平县| 呼伦贝尔市| 阜宁县| 香港| 南华县| 岳西县| 白朗县| 乡宁县| 卢氏县| 双桥区| 新宾| 科尔| 临沧市| 隆昌县| 监利县| 南通市| 木兰县| 山东| 久治县| 息烽县| 那曲县| 渑池县| 赤峰市| 芒康县| 广元市| 田林县| 安徽省| 措美县| 托克托县|