日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

在Vue中創(chuàng)建可重用的 Transition的方法

瀏覽:195日期:2023-01-16 14:31:01

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

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

在Vue中創(chuàng)建可重用的 Transition的方法

原始transition組件和CSS

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

<template> <div id='app'> <button v-on:click='show = !show'> Toggle </button> <transition name='fade'> <p v-if='show'>hello</p> </transition> </div> </template> <script> export default { name: 'App', data() { return { show: true }; } }; </script> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.3s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> 在Vue中創(chuàng)建可重用的 Transition的方法

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

封裝transition組件

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

// FadeTransition.vue <template> <transition name='fade'> <slot></slot> </transition> </template> <script> export default { }; </script> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.3s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> // App.vue <template> <div id='app'> <button v-on:click='show = !show'> Toggle transition </button> <fade-transition> <div v-if='show' class='box'></div> </fade-transition> </div> </template> <script>...</script> <style>...</style>

在Vue中創(chuàng)建可重用的 Transition的方法

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

封裝的包裝器transition組件

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

// FadeTransition.vue <template> <transition name='fade' v-bind='$attrs' v-on='$listeners'> <slot></slot> </transition> </template> <script> export default {}; </script> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.3s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> // App.vue ... <fade-transition mode='out-in'> <div key='blue' v-if='show' class='box'></div> <div key='red' v-else class='red-box'></div> </fade-transition> ... 在Vue中創(chuàng)建可重用的 Transition的方法

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

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

顯式持續(xù)時間 prop

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

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

// FadeTransition.vue <template> <transition name='fade' enter-active- leave-active- v-bind='$attrs' v-on='hooks'> <slot></slot> </transition> </template> <script> export default { props: { duration: { type: Number, default: 300 } }, computed: { hooks() { return { beforeEnter: this.setDuration, afterEnter: this.cleanUpDuration, beforeLeave: this.setDuration, afterLeave: this.cleanUpDuration, ...this.$listeners }; } }, methods: { setDuration(el) { el.style.animationDuration = `${this.duration}ms`; }, cleanUpDuration(el) { el.style.animationDuration = ''; } } }; </script> <style> @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } .fadeIn { animation-name: fadeIn; } @keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } } .fadeOut { animation-name: fadeOut; } </style> 在Vue中創(chuàng)建可重用的 Transition的方法

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

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

Transition group 支持

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

// FadeTransition.vue <template> <component :is='type' :tag='tag' enter-active- leave-active- move- v-bind='$attrs' v-on='hooks'> <slot></slot> </component> </template> <script> export default { props: { duration: { type: Number, default: 300 }, group: { type: Boolean, default: false }, tag: { type: String, default: 'div' } }, computed: { type() { return this.group ? 'transition-group' : 'transition'; }, hooks() { return { beforeEnter: this.setDuration, afterEnter: this.cleanUpDuration, beforeLeave: this.setDuration, afterLeave: this.cleanUpDuration, leave: this.setAbsolutePosition, ...this.$listeners }; } }, methods: { setDuration(el) { el.style.animationDuration = `${this.duration}ms`; }, cleanUpDuration(el) { el.style.animationDuration = ''; }, setAbsolutePosition(el) { if (this.group) { el.style.position = 'absolute'; } } } }; </script> <style> @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } } .fadeIn { animation-name: fadeIn; } @keyframes fadeOut { from { opacity: 1; } to { opacity: 0; } } .fadeOut { animation-name: fadeOut; } .fade-move { transition: transform 0.3s ease-out; } </style> // App.vue ... <div class='box-wrapper'> <fade-transition group :duration='300'> <div v-for='(item, index) in list' @click='remove(index)' :key='item' > </div> </fade-transition> </div> ... 在Vue中創(chuàng)建可重用的 Transition的方法

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

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

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

Vue Transition

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

總結(jié)

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

到此這篇關(guān)于在Vue中創(chuàng)建可重用的 Transition的方法的文章就介紹到這了,更多相關(guān)vue創(chuàng)建Transition內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩一视频区二区| 精品国产乱码久久久久久樱花| 亚洲免费福利| 亚洲永久av| 日韩高清中文字幕一区二区| 99热精品久久| 亚洲一区二区三区免费在线观看| 亚洲欧美激情诱惑| 亚洲一区二区免费在线观看| 日韩在线观看中文字幕| 国产毛片一区二区三区| 国产videos久久| 群体交乱之放荡娇妻一区二区| 久久久久久久久久久9不雅视频| 精品一区欧美| 亚洲高清av| 亚洲久久在线| 国产精品男女| 免费在线小视频| 亚洲欧美日韩视频二区| 97久久亚洲| 日韩免费福利视频| 老司机久久99久久精品播放免费| 青青青国产精品| 日韩a一区二区| 婷婷精品进入| 国产欧美视频在线| 成人羞羞在线观看网站| 日韩一区精品字幕| 美女在线视频一区| 99国产精品一区二区| 亚洲精品综合| 97欧美在线视频| 另类av一区二区| 精品国产一级| 亚洲香蕉网站| 国产精品一级| 2023国产精品久久久精品双| 7777精品| 红桃视频国产精品| 国产精品极品| 在线 亚洲欧美在线综合一区| 久久精品凹凸全集| 精品在线99| 美女国产一区二区三区| 欧美+亚洲+精品+三区| 国产日韩精品视频一区二区三区| 99久久激情| 免费在线观看一区| 亚洲毛片网站| 久久一区二区三区喷水| 国产精品99久久免费| 亚洲一区二区毛片| 偷拍精品精品一区二区三区| 国产精品日本一区二区三区在线| 日韩视频久久| 日韩免费高清| 久久精品伊人| 91麻豆精品激情在线观看最新| 国产精品97| 久久久国产精品入口麻豆| 亚洲精品系列| 亚洲激情偷拍| 少妇久久久久| 日韩1区在线| 免费在线日韩av| 青青草国产成人99久久| 亚洲午夜免费| 日韩精品一区第一页| 激情综合网站| 日韩精品一区二区三区免费观看| 国产精品videossex| 伊人www22综合色| 欧美日韩国产传媒| 色爱av综合网| 精品三区视频| 国产精品永久| 97久久中文字幕| 少妇精品久久久| 亚洲欧美日韩国产综合精品二区| 国产韩日影视精品| 亚洲午夜av| 亚洲午夜黄色| 国产精品91一区二区三区| 成人免费电影网址| 日韩精品一区二区三区免费观看| 韩国三级一区| 99成人在线视频| 亚洲成人二区| 久久精品高清| 欧美91视频| 婷婷亚洲五月| 日韩一区精品字幕| 日韩精品免费一区二区夜夜嗨| 日本在线视频一区二区| 亚洲精品美女| 日韩二区三区四区| 91欧美极品| 国产精品www994| 精品国产鲁一鲁****| 成人一区而且| 久久国产小视频| 亚洲免费播放| 日韩中文av| 国产精品探花在线观看| 国产欧美视频在线| 欧美激情视频一区二区三区免费| 国产精品成人3p一区二区三区| 美女在线视频一区| 亚洲精品福利电影| 亚洲精品va| 蜜桃视频在线观看一区| 欧美三区不卡| 久久久久免费| 亚洲精品一二三区区别| 综合国产在线| 国产精品2023| 日韩在线视频精品| 狠狠色狠狠色综合日日tαg| 亚洲v天堂v手机在线| 国产亚洲字幕| 福利一区和二区| 午夜久久美女| 欧美日韩中出| 亚洲天堂一区二区| 中文字幕日本一区| 福利视频一区| 日韩在线观看一区二区| 国产精品66| 亚洲精品91| 欧美黑人巨大videos精品| 日韩精品欧美激情一区二区| 玖玖精品视频| 精品视频97| 午夜在线视频一区二区区别| 日韩精品午夜视频| 神马午夜在线视频| 日韩中文字幕一区二区三区| 欧美激情视频一区二区三区免费| 免费观看不卡av| 国产精品任我爽爆在线播放| 伊人精品一区| 免费日韩成人| 中文视频一区| 亚洲国产福利| 91精品国产自产在线丝袜啪| 欧美日韩精品免费观看视欧美高清免费大片| 久久福利毛片| zzzwww在线看片免费| 亚洲人成毛片在线播放女女| 日韩成人精品一区二区| 亚洲精品国模| 欧美69视频| 久久久久久夜| 日韩二区在线观看| 欧美日韩国产免费观看| 久久精品理论片| 亚洲一区二区小说| 四虎4545www国产精品 | 啪啪国产精品| 国产欧美日韩视频在线| 日韩一区欧美| 国产精品成人国产| 男女激情视频一区| 日韩一区二区三区免费播放| 欧美日韩亚洲一区三区| 亚洲视频播放| 色天使综合视频| 国产精品久久乐| 亚洲精品极品| 亚洲一区中文| 久久久国产亚洲精品| 美女毛片一区二区三区四区最新中文字幕亚洲 | 久久中文字幕一区二区三区| 免费日韩av片| 久久久久久久久久久妇女| 国产福利一区二区精品秒拍| 伊人久久大香伊蕉在人线观看热v| 午夜精品久久久久久久久久蜜桃| 久久超级碰碰| 国产一卡不卡| 午夜久久av| 免费久久精品视频| 日韩视频在线一区二区三区 | 欧美a一区二区| 爽好多水快深点欧美视频| 久久精品主播| 97精品中文字幕| 国产不卡精品| 麻豆成人91精品二区三区| 综合欧美精品| 水野朝阳av一区二区三区| 国产精品97| 99国产精品久久久久久久成人热 | 亚洲精品成人一区| 男女男精品视频网| 亚洲精品婷婷| 奇米色欧美一区二区三区| 日韩激情中文字幕| 日韩精品国产欧美|