Vue中的CSS transition和animation

1. Vue中的CSS transition過渡

當我們插入一個元素的時候,vue會在過渡的第0幀給<transition name="fade">標上"fade-enter","fade-enter-active"兩個類名, 在過渡的第一幀刪除"fade-enter"扮宠,添加上"fade-enter-to", 在整個過渡動畫結束之后西乖,刪除"fade-enter-to"和"fade-enter-active"類名。我們可以認為"fade-enter"和"fade-enter-to"是<transition>包裹的元素的兩個狀態(tài)坛增,當我們在"fade-enter-active"中加入CSS transition rule, 就可以在整個過渡動畫過程中檢測到狀態(tài)的變化获雕,其實兩個狀態(tài)的切換往往就在第0幀和第1幀,檢測到這一狀態(tài)變化之后收捣,css transition就會開始届案。

enter.png

刪除一個元素的時候流程也是相似的:
leave.png

細節(jié)

<transition :duration='5000'>
    <div>hello</div>
</transition>
<style>
.v-enter,.v-leave-to{
    opacity: 0;
}
.v-enter-active,.v-leave-active{
    transition: all 1s ease;
}
</style>
  1. 我們可以顯式定義過渡動畫的持續(xù)時間。上述代碼中罢艾,盡管transition:opacity的過渡動畫在1s后就完成了楣颠,但是v-enter-to,v-enter-active兩個類名會保持到5s結束。
  2. 因為transition其實是兩個狀態(tài)的切換咐蚯,在實際情況中童漩,.v-enter, .v-leave-to表示的其實是一個狀態(tài),因此往往采用相同的CSS rules春锋。

2. Vue中的CSS animation動畫

我們都知道CSS3中的animation不像transition需要狀態(tài)改變來觸發(fā)矫膨,因此我們可以直接在.v-enter-active,.v-leave-active中應用animation。我們可以自己通過keyframes自己創(chuàng)建動畫,也可以引用外部的CSS動畫庫豆拨,比如說animated.css直奋,里面是很多已經寫好的keyframes動畫。

3. 同時結合transition和animation的一個栗子

<style>    
       .slide-enter,.slide-leave-to{
                opacity: 0;
            }
            .slide-enter-active{
                transition: all 1s;
            }
            .slide-leave-active{
                transition: all 1s;
            }
</style>

        <div id="root">
            <button @click="show=!show">toggle</button>
            <transition 
            :duration="5000"
            name="slide" 
            appear
            enter-active-class="animated slideInUp slide-enter-active"
            leave-active-class="animated slideOutDown slide-leave-active"
            appear-active-class="animated slideInUp slide-enter-active">
                <div v-show="show">Hello</div>
            </transition>
        </div>
<script>
            const app=new Vue({
                el:"#root",
                data:{
                    show:true,
                }
            });
</script>
參考資料:
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末施禾,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子搁胆,更是在濱河造成了極大的恐慌弥搞,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件渠旁,死亡現(xiàn)場離奇詭異攀例,居然都是意外死亡,警方通過查閱死者的電腦和手機顾腊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門粤铭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人杂靶,你說我怎么就攤上這事梆惯。” “怎么了吗垮?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵垛吗,是天一觀的道長。 經常有香客問我烁登,道長怯屉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任饵沧,我火速辦了婚禮锨络,結果婚禮上,老公的妹妹穿的比我還像新娘狼牺。我一直安慰自己羡儿,他們只是感情好,可當我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布锁右。 她就那樣靜靜地躺著失受,像睡著了一般。 火紅的嫁衣襯著肌膚如雪咏瑟。 梳的紋絲不亂的頭發(fā)上拂到,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天,我揣著相機與錄音码泞,去河邊找鬼兄旬。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的领铐。 我是一名探鬼主播悯森,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼绪撵!你這毒婦竟也來了瓢姻?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤音诈,失蹤者是張志新(化名)和其女友劉穎幻碱,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體细溅,經...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡褥傍,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了喇聊。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片恍风。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖誓篱,靈堂內的尸體忽然破棺而出朋贬,到底是詐尸還是另有隱情,我是刑警寧澤燕鸽,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布兄世,位于F島的核電站,受9級特大地震影響啊研,放射性物質發(fā)生泄漏御滩。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一党远、第九天 我趴在偏房一處隱蔽的房頂上張望削解。 院中可真熱鬧,春花似錦沟娱、人聲如沸氛驮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽矫废。三九已至,卻和暖如春砰蠢,著一層夾襖步出監(jiān)牢的瞬間蓖扑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工台舱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留律杠,地道東北人。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像柜去,于是被迫代替她去往敵國和親灰嫉。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,435評論 2 359