javascript - vue過渡效果 css過渡 類名的先后順序
問題描述
給一個元素設(shè)計過渡,理想效果是出現(xiàn)時高度遞增,消失是高度遞減。設(shè)計的代碼如下:
.collapse-enter-active, .collapse-leave-active { transition: height .5s;}.collapse-enter, .collapse-leave-active { height: 0;}.collapse-leave { height: 100px;} .collapse-enter-active { height: 100px;}
結(jié)果元素出現(xiàn)時,高度直接到達(dá)100px,消失時正常,修改代碼的順序如下:
.collapse-enter-active, .collapse-leave-active { transition: height .5s;}.collapse-enter-active { height: 100px;}.collapse-enter, .collapse-leave-active { height: 0;}.collapse-leave { height: 100px;}
問題解決了,不明白順序為什么會造成影響,過渡效果不是在通過切換css來實現(xiàn)的么,應(yīng)該不是覆蓋的問題吧?具體效果可以點擊查看 jsbin
問題解答
回答1:@CRIMX 的答案已經(jīng)講清楚了,本質(zhì)上就是 enter 和 enter active 兩個類會在第一幀同時存在于動畫元素上,而后通過移除 enter 類執(zhí)行動畫,因此不能讓 active 類的樣式提前生效。
兩個類的方式雖然足以完成動畫,但確實不太容易理解,所以 vue 2.1.8 開始增加了 to 的類名,可以將動畫的結(jié)束態(tài)從 active 類中剝離出來,更方便理解,避免產(chǎn)生順序覆蓋問題。
回答2:在元素被插入時 v-enter 和 v-enter-active 同時生效的,前者在下一幀移除,后者在動畫完成后移除。所以 v-enter-active 要寫在前面。leave 也一樣。
回答3:這個真是挺奇怪的, 下次寫把active寫前面, 坐等高人來解惑
回答4:你可以看一下官網(wǎng)給的解釋,說的很詳細(xì):https://cn.vuejs.org/v2/guide/transitions.html#過渡的-CSS-類名
相關(guān)文章:
1. 在應(yīng)用配置文件 app.php 中找不到’route_check_cache’配置項2. html按鍵開關(guān)如何提交我想需要的值到數(shù)據(jù)庫3. HTML 5輸入框只能輸入漢字、字母、數(shù)字、標(biāo)點符號?正則如何寫?4. dockerfile - 我用docker build的時候出現(xiàn)下邊問題 麻煩幫我看一下5. gvim - 誰有vim里CSS的Indent文件, 能縮進(jìn)@media里面的6. 跟著課件一模一樣的操作使用tp6,出現(xiàn)了錯誤7. PHP類屬性聲明?8. javascript - 請教如何獲取百度貼吧新增的兩個加密參數(shù)9. html - 微信瀏覽器h5<video>標(biāo)簽問題10. java - 安卓接入微信登錄,onCreate不會執(zhí)行
