亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

聊一聊Vue.js過渡效果

 更新時間:2016年09月07日 09:14:29   投稿:lijiao  
這篇文章主要和大家一起聊一聊Vue.js過渡效果、CSS 過渡效果、純 JavaScript過渡效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

通過 Vue.js 的過渡系統(tǒng),你可以輕松的為 DOM 節(jié)點(diǎn)被插入/移除的過程添加過渡動畫效果。Vue 將會在適當(dāng)?shù)臅r機(jī)添加/移除 CSS 類名來觸發(fā) CSS3 過渡/動畫效果,你也可以提供相應(yīng)的 JavaScript 鉤子函數(shù)在過渡過程中執(zhí)行自定義的 DOM 操作。

v-transition="my-transition" 這個指令為例,當(dāng)帶有這個指令的 DOM 節(jié)點(diǎn)被插入或移除時,Vue 將會:

my-transition 這個 ID 去查找是否有注冊過的 JavaScript 鉤子對象。這個對象可以是由 Vue.transition(id, hooks) 全局注冊,或是通過 transitions 選項定義在當(dāng)前的組件內(nèi)部。如果找到此對象,則會在過渡動畫不同的階段調(diào)用相應(yīng)的鉤子。

自動探測目標(biāo)元素是否應(yīng)用了 CSS 過渡效果或者動畫效果,并在適當(dāng)?shù)臅r機(jī)添加/移除 CSS 類名。

如果沒有提供 JavaScript 鉤子函數(shù),也沒有檢測到相應(yīng)的 CSS 過渡/動畫效果,DOM 的插入/移除會在下一幀立即執(zhí)行。
所有的 Vue.js 過渡效果只有在該 DOM 操作是通過 Vue.js 觸發(fā)時才會生效。觸發(fā)的方式可以是通過內(nèi)置指令,比如 v-if,或是通過 Vue 實(shí)例的方法,比如 vm.$appendTo()。

CSS 過渡效果
一個典型的 CSS 過渡效果定義如下:

<div v-if="show" v-transition="expand">hello</div>

你還需要定義 .expand-transition, .expand-enter 和.expand-leave 三個 CSS 類:

.expand-transition {
 transition: all .3s ease;
 height: 30px;
 padding: 10px;
 background-color: #eee;
 overflow: hidden;
}
.expand-enter, .expand-leave {
 height: 0;
 padding: 0 10px;
 opacity: 0;
}

同時,你也可以提供 JavaScript 鉤子:

Vue.transition('expand', {
 beforeEnter: function (el) {
  el.textContent = 'beforeEnter'
 },
 enter: function (el) {
  el.textContent = 'enter'
 },
 afterEnter: function (el) {
  el.textContent = 'afterEnter'
 },
 enterCancelled: function (el) {
  // handle cancellation
 },
`
 beforeLeave: function (el) {
  el.textContent = 'beforeLeave'
 },
 leave: function (el) {
  el.textContent = 'leave'
 },
 afterLeave: function (el) {
  el.textContent = 'afterLeave'
 },
 leaveCancelled: function (el) {
  // handle cancellation
 }
})

結(jié)果

這里使用的 CSS 類名由 v-transition 指令的值所決定。以 v-transition="fade" 為例,CSS 類 .fade-transition 將會一直存在,而 .fade-enter 和 .fade-leave 將會在合適的時機(jī)自動被添加或移除。當(dāng) v-transition 指令沒有提供值的時候,所使用的 CSS 類名將會是默認(rèn)的 .v-transition, .v-enter 和 .v-leave。

當(dāng) show 屬性變化時,Vue 會依據(jù)其當(dāng)前的值來插入/移除 <div> 元素,并在合適的時機(jī)添加/移除對應(yīng)的 CSS 類,具體如下:

當(dāng) show 變?yōu)?false 時,Vue 將會:

1.調(diào)用 beforeLeave 鉤子;
2.在元素上應(yīng)用 CSS 類 .v-leave 來觸發(fā)過渡效果;
3.調(diào)用 leave 鉤子;
4.等待過渡效果執(zhí)行完畢; (監(jiān)聽 transitionend 事件)
5.從 DOM 中移除元素并且移除 CSS 類 .v-leave。
6.調(diào)用 afterLeave 鉤子。

當(dāng) show 為 true 時,Vue 將會:

1.調(diào)用 beforeEnter 鉤子;
2.在元素上應(yīng)用 CSS 類 .v-enter;
3.將元素插入 DOM;
4.調(diào)用 enter 鉤子;
5.應(yīng)用 .v-enter 類, 然后強(qiáng)制 CSS 布局以保證 .v-enter 生效;最后移除 .v-enter 來觸發(fā)元素過渡到原本的狀態(tài)。
6.等待過渡效果執(zhí)行完畢;
7.調(diào)用 afterEnter 鉤子。

此外,如果一個正在執(zhí)行進(jìn)入的過渡效果的元素在過渡還未完成之前就被移除,則 enterCancelled 鉤子將會被執(zhí)行。這個鉤子可以用于清理工作,比如移除在 enter 時創(chuàng)建的計時器。對于正在離開過渡中又被重新插入的元素同理。

上述所有的鉤子函數(shù)執(zhí)行時,其 this 都指向相應(yīng)的 Vue 實(shí)例。如果一個元素本身是一個 Vue 實(shí)例的根節(jié)點(diǎn),則此實(shí)例將被應(yīng)用為 this;否則 this 指向該過渡指令所屬的實(shí)例。

最后,enter 與 leave 鉤子函數(shù)可以接受可選的第二個參數(shù):一個回調(diào)函數(shù)。當(dāng)你的函數(shù)簽名中含有第二個參數(shù)時,即表示你期望使用此回調(diào)來顯式地完成整個過渡過程,而不是依賴 Vue 去自動檢測 CSS 過渡的 transitionend 事件。比如:

enter: function (el) {
 // 無第二個參數(shù)
 // 過渡效果的結(jié)束由 CSS 過渡結(jié)束事件來決定
}

VS

enter: function (el, done) {
 // 有第二個參數(shù)
 // 過渡效果結(jié)束必須由手動調(diào)用 `done` 來決定
}

當(dāng)多個元素同時執(zhí)行過渡效果時,Vue.js 會進(jìn)行批量處理以保證只觸發(fā)一次強(qiáng)制布局。

CSS 動畫
CSS 動畫通過與 CSS 過渡效果一樣的方式進(jìn)行調(diào)用,區(qū)別就是動畫中 .v-enter 類并不會在節(jié)點(diǎn)插入 DOM 后馬上移除,而是在 animationend 事件觸發(fā)時移除。

示例: (省略了兼容性前綴)

<span v-show="show" v-transition="bounce">Look at me!</span>

.bounce-enter {
 animation: bounce-in .5s;
}
.bounce-leave {
 animation: bounce-out .5s;
}
@keyframes bounce-in {
 0% {
  transform: scale(0);
 }
 50% {
  transform: scale(1.5);
 }
 100% {
  transform: scale(1);
 }
}
@keyframes bounce-out {
 0% {
  transform: scale(1);
 }
 50% {
  transform: scale(1.5);
 }
 100% {
  transform: scale(0);
 }
}

結(jié)果

純 JavaScript 過渡效果
你也可以只使用 JavaScript 鉤子,不定義任何 CSS 過渡規(guī)則。當(dāng)只使用 JavaScript 鉤子時,enter 和 leave 鉤子必須使用 done 回調(diào),否則它們將會被同步調(diào)用,過渡將立即結(jié)束。下面的示例中我們使用 jQuery 來注冊一個自定義的 JavaScript 過渡效果:

Vue.transition('fade', {
 enter: function (el, done) {
  // 此時元素已被插入 DOM
  // 動畫完成時調(diào)用 done 回調(diào)
  $(el)
   .css('opacity', 0)
   .animate({ opacity: 1 }, 1000, done)
 },
 enterCancelled: function (el) {
  $(el).stop()
 },
 leave: function (el, done) {
  // 與 enter 鉤子同理
  $(el).animate({ opacity: 0 }, 1000, done)
 },
 leaveCancelled: function (el) {
  $(el).stop()
 }
})

定義此過渡之后,你就可以通過給 v-transition 指定對應(yīng)的 ID 來調(diào)用它:

<p v-transition="fade"></p>

如果一個只使用 JavaScript 過渡效果的元素恰巧也受到其它 CSS 過渡/動畫規(guī)則的影響,這可能會對 Vue 的 CSS 過渡檢測機(jī)制產(chǎn)生干擾。碰到這樣的狀況時,你可以通過給你的鉤子對象添加 css: false 來禁止 CSS 檢測。

漸進(jìn)過渡效果
當(dāng)同時使用 v-transition 和 v-repeat 時,我們可以為列表元素添加漸進(jìn)的過渡效果,你只需要為你的過渡元素加上 stagger, enter-stagger 或者 leave-stagger 特性(以毫秒為單位):

<div v-repeat="list" v-transition stagger="100"></div>

或者你也可以提供 stagger, enterStagger 或 eaveStagger 鉤子來進(jìn)行更細(xì)粒度的控制:

Vue.transition('stagger', {
 stagger: function (index) {
  // 為每個過渡元素增加 50ms 的延遲,
  // 但是最大延遲為 300ms
  return Math.min(300, index * 50)
 }
})


示例:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法

    vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法

    這篇文章主要介紹了vue路由攔截及頁面跳轉(zhuǎn)的設(shè)置方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • vue form check 表單驗證的實(shí)現(xiàn)代碼

    vue form check 表單驗證的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue form check 表單驗證的實(shí)現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-12-12
  • vue自定義指令directive實(shí)例詳解

    vue自定義指令directive實(shí)例詳解

    這篇文章主要介紹了vue自定義指令directive的相關(guān)資料,下面通過實(shí)例給大家介紹,需要的朋友可以參考下
    2018-01-01
  • 使用vue-resource進(jìn)行數(shù)據(jù)交互的實(shí)例

    使用vue-resource進(jìn)行數(shù)據(jù)交互的實(shí)例

    下面小編就為大家?guī)硪黄褂胿ue-resource進(jìn)行數(shù)據(jù)交互的實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Element Plus的el-icon怎么用

    Element Plus的el-icon怎么用

    在Element Plus里,Icon圖標(biāo)的用法和以前不一樣了,本文主要介紹了Element Plus的el-icon怎么用,具有一定的參考價值,感興趣的可以了解一下
    2022-04-04
  • vue前后端分離如何解決每次請求session都會變的問題

    vue前后端分離如何解決每次請求session都會變的問題

    這篇文章主要介紹了vue前后端分離如何解決每次請求session都會變的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 在 Vue 中使用 JSX 及使用它的原因淺析

    在 Vue 中使用 JSX 及使用它的原因淺析

    這篇文章主要介紹了在 Vue 中使用 JSX 及使用它的原因淺析,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-02-02
  • 詳解vue-cli 腳手架項目-package.json

    詳解vue-cli 腳手架項目-package.json

    本篇文章主要介紹了詳解vue-cli 腳手架項目-package.json,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • vue?懶加載組件chunk相對路徑混亂問題及解決

    vue?懶加載組件chunk相對路徑混亂問題及解決

    這篇文章主要介紹了vue?懶加載組件chunk相對路徑混亂問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 淺談Vue 函數(shù)式組件的使用技巧

    淺談Vue 函數(shù)式組件的使用技巧

    這篇文章主要介紹了淺談Vue 函數(shù)式組件的使用技巧,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06

最新評論