国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

javascript - vue過渡效果 css過渡 類名的先后順序

瀏覽:63日期:2023-05-26 15:21:44

問題描述

給一個元素設計過渡,理想效果是出現時高度遞增,消失是高度遞減。設計的代碼如下:

.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;}

結果元素出現時,高度直接到達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來實現的么,應該不是覆蓋的問題吧?具體效果可以點擊查看 jsbin

問題解答

回答1:

@CRIMX 的答案已經講清楚了,本質上就是 enter 和 enter active 兩個類會在第一幀同時存在于動畫元素上,而后通過移除 enter 類執行動畫,因此不能讓 active 類的樣式提前生效。

兩個類的方式雖然足以完成動畫,但確實不太容易理解,所以 vue 2.1.8 開始增加了 to 的類名,可以將動畫的結束態從 active 類中剝離出來,更方便理解,避免產生順序覆蓋問題。

回答2:

在元素被插入時 v-enter 和 v-enter-active 同時生效的,前者在下一幀移除,后者在動畫完成后移除。所以 v-enter-active 要寫在前面。leave 也一樣。

回答3:

這個真是挺奇怪的, 下次寫把active寫前面, 坐等高人來解惑

回答4:

你可以看一下官網給的解釋,說的很詳細:https://cn.vuejs.org/v2/guide/transitions.html#過渡的-CSS-類名

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产成人在线综合 | 午夜欧美精品久久久久久久久 | 日本免费一区二区三区a区 日本免费一区二区三区看片 | 亚洲一区二区三区高清 | 久久久久久久久久久久久久久久久久 | 国产欧美日韩视频在线观看一区二区 | 日韩欧美高清在线观看 | 国产一区二区亚洲精品 | 99精品视频在线这里只有 | 男人添女人下面免费毛片 | 欧美大片在线观看成人 | 亚洲一区二区精品视频 | 免费一级毛片在级播放 | 性高湖久久久久久久久 | 国产91一区二区在线播放不卡 | 亚洲国产天堂久久综合网站 | 美女福利视频国产 | 九九精品视频在线播放8 | 国产激情久久久久影 | 成年人免费网站在线观看 | 在线视频一区二区日韩国产 | 久久99国产乱子伦精品免 | 91久久国产 | yy6080久久亚洲精品 | 国产成人一区在线播放 | 国产一区二区三区免费视频 | 国产丝袜美女一区二区三区 | 日韩一区二区天海翼 | 欧美粗又大gay69视频 | 国产亚洲欧美久久精品 | 99爱精品视频 | 成人a毛片在线看免费全部播放 | 国产成人精品曰本亚洲78 | 特级一级毛片视频免费观看 | 国产成人精品女人不卡在线 | 亚洲天堂成人 | 精品91自产拍在线 | 欧美成人区 | 国产欧美日韩一区二区三区在线 | 欧美孕交视频 | 亚洲 欧美 国产 日韩 制服 bt |