日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
在Vue中創(chuàng)建可重用的Transition

本文轉(zhuǎn)載自微信公眾號「大遷世界」,轉(zhuǎn)載本文請聯(lián)系大遷世界公眾號。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:申請域名、網(wǎng)絡(luò)空間、營銷軟件、網(wǎng)站建設(shè)、樂平網(wǎng)站維護(hù)、網(wǎng)站推廣。

Vue.js中的transition確實(shí)很棒。毫無疑問,它們可以非常輕松地讓應(yīng)用程序栩栩如生,但是通常必須在每個項(xiàng)目中從頭開始編寫它們,甚至還需要引入animate.css之類的CSS庫來使它們功能更強(qiáng)大。

如果我們可以將它們封裝到組件中,并在多個項(xiàng)目中簡單地重用它們,結(jié)果會怎樣呢?我們將介紹幾種定義transition的方法,并深入研究如何使它們真正可重用。

原始transition組件和CSS

定義transition的最簡單方法是使用transition·或transition-group組件。這需要為transition定義一個name`和一些CSS。

 
 
 
 

看起來容易,對吧?然而,這種方法有一個問題。我們不能在另一個項(xiàng)目中真正重用這個transition。

封裝transition組件

如果我們將前面的邏輯封裝到一個組件中,并將其用作一個組件,結(jié)果會怎樣呢?

 
 
 
 
  1. // FadeTransition.vue
  2. // App.vue

通過在transition組件中提供一個slot,我們幾乎可以像使用基本transition組件一樣使用它。這比前面的例子稍微好一點(diǎn),但是如果我們想要傳遞其他特定于transition的prop,比如mode或者一些hook,該怎么辦呢

封裝的包裝器transition組件

幸運(yùn)的是,Vue 中有一個功能,使我們可以將用戶指定的所有額外props和監(jiān)聽器傳遞給我們的內(nèi)部標(biāo)簽/組件。如果你還不知道,則可以通過$attrs訪問額外傳遞的 props,并將它們與v-bind結(jié)合使用以將它們綁定為props。這同樣適用于通過$listeners進(jìn)行的事件,并通過v-on對其進(jìn)行應(yīng)用。

 
 
 
 
  1. // FadeTransition.vue
  2. // App.vue
  3. ...
  4.   
  •   
  • ...
  •  

    「完整事例地址:https://codesandbox.io/s/yjl1wjyoy1?from-embed」

    現(xiàn)在,我們可以傳遞普通transition組件可以接受的任何事件和支持,這使得我們的組件更加可重用。但為什么不更進(jìn)一步,增加通過 prop 輕松定制持續(xù)時間的可能性。

    顯式持續(xù)時間 prop

    Vue 為transition組件提供了一個duration prop,然而,它是為更復(fù)雜的動畫鏈接而設(shè)計的,它幫助 Vue 正確地將它們鏈接在一起。

    在我們的案例中,我們真正需要的是通過組件prop控制CSS animation/transition。我們可以通過不在CSS中指定顯式的CSS動畫持續(xù)時間,而是將其作為樣式來實(shí)現(xiàn)。我們可以借助transition hook來做到這一點(diǎn),該transition hook與組件生命周期 hook 非常相似,但是它們在過渡所需元素之前和之后被調(diào)用。讓我們看看效果如何。

     
     
     
     
    1. // FadeTransition.vue

    「完整事例地址:https://codesandbox.io/s/j4qnjvmwz9?from-embed」

    現(xiàn)在,我們可以控制實(shí)際的可見過渡時間,這使我們可重用的過渡變得靈活且易于使用。但是,如何過渡多個元素(如列表項(xiàng))呢?

    Transition group 支持

    你想到的最直接的方法可能是創(chuàng)建一個新組件,比如fade-transition-group,然后將當(dāng)前transition標(biāo)簽替換為transition-group標(biāo)簽,以實(shí)現(xiàn) group transition。如果我們可以在相同的組件中這樣做,并公開一個將切換到transition-group實(shí)現(xiàn)的group prop,那會怎么樣呢?幸運(yùn)的是,我們可以通過render函數(shù)或component和is屬性來實(shí)現(xiàn)這一點(diǎn)。

     
     
     
     
    1. // FadeTransition.vue
    2. // App.vue
    3. ...
    4.   
    5.     
    6.          v-for="(item, index) in list"
    7.          @click="remove(index)"
    8.          :key="item"
    9.      >
    10.     
  •   
  • ...
  • 「完整事例地址:https://codesandbox.io/s/pk9r5j2257?from-embed」

    [文檔中][6]介紹了一個帶有transition-group元素的警告。我們基本上必須在元素離開時將每個項(xiàng)目的定位設(shè)置為absolute,以實(shí)現(xiàn)其他項(xiàng)目的平滑移動動畫。我們也必須添加一個move-class并手動指定過渡持續(xù)時間,因?yàn)闆]有用于移動的 JS hook。我們將這些調(diào)整添加到我們的上一個示例中。

    再做一些調(diào)整,通過在mixin中提取 JS 邏輯,我們可以將其應(yīng)用于輕松創(chuàng)建新的transition組件,只需將其放入下一個項(xiàng)目中即可。

    Vue Transition

    在此之前描述的所有內(nèi)容基本上都是這個小型 [transition 集合][7]所包含的內(nèi)容。它有 10 個封裝的transition組件,每個約1kb(縮小)。我認(rèn)為它非常方便,可以輕松地在不同的項(xiàng)目中使用。你可以試一試:)

    總結(jié)

    我們從一個基本的過渡示例開始,并最終通過可調(diào)整的持續(xù)時間和transition-group支持來創(chuàng)建可重用的過渡組件。我們可以使用這些技巧根據(jù)并根據(jù)自身的需求創(chuàng)建自己的過渡組件。希望讀者從本文中學(xué)到了一些知識,并且可以幫助你們建立功能更好的過渡組件。


    當(dāng)前名稱:在Vue中創(chuàng)建可重用的Transition
    文章起源:http://www.5511xx.com/article/djoieoc.html