日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue-transition多元素过渡

發布時間:2023/12/16 vue 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue-transition多元素过渡 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • 多個元素過渡(設置key)
    *當有相同標簽名的元素切換時,需要通過 key 特性設置唯一的值來標記以讓 Vue 區分它們,否則 Vue 為 了效率只會替換相同標簽內部的內容。
    mode:in-out ; out-in
  • <style>.kerwin-enter-active,.kerwin-leave-active {transition: all .5s}.kerwin-enter,.kerwin-leave-to {opacity: 0;transform: translateX(100px);}.bounce-enter-active {animation: bounce-in .5s;}.bounce-leave-active {animation: bounce-in .5s reverse;}@keyframes bounce-in {0% {transform: translateX(100px);opacity: 0;}100% {transform: translateX(0px);opacity: 1;}}</style>
  • 利用條件編譯指令v-if與v-else實現多元素內容切換
  • transition添加name屬性命名
  • 設置過渡狀態
  • 狀態管理
    • 測試后發現并沒有過渡效果,分析原因Vue在多個元素切換過程中會盡量復用DOM,如果不加key,那么vue會選擇復用節點(Vue的就地更新策略),導致之前節點的狀態被保留下來,由此產生一系列的bug。
    • 方案:給多元素添加不同key進行狀態管理
    <div id="box"><button @click="isShow= !isShow">click</button><transition name="bounce" mode="out-in"><p v-if="isShow" key="1">11111111111</p><div v-else>tramisu</div><p v-else key="2">222222222</p></transition></div><script src="http://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script><script>var vm = new Vue({el: "#box",data: {isShow: true}})</script>
    • ①in-out:新元素先進行過渡,完成之后當前元素過渡離開(不是經常用到,但對于一些稍微不同的過渡效果還是有用的)
    • ②out-in:當前元素先進行過渡,完成之后新元素過渡進入

    總結

    以上是生活随笔為你收集整理的vue-transition多元素过渡的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。