<thead id="kdfuf"><font id="kdfuf"></font></thead>
<samp id="kdfuf"></samp>
    <nav id="kdfuf"><strong id="kdfuf"></strong></nav>
      中文字幕无码一区二区三区在线,久久精品人人做人人爽,国产一级内射无挡观看,十八禁在线黄色网站,日韩欧美国产另类久久久精品 ,少妇人妻偷人精品一区二区,久久午夜视频,亚洲春色AⅤ无码专区

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

      2020-5-21    seo達(dá)人

      原始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>

      圖片描述


      看起來容易,對吧?然而,這種方法有一個問題。我們不能在另一個項(xiàng)目中真正重用這個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>

      圖片描述


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


      封裝的包裝器transition組件

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


      ...

      圖片描述


      完整事例地址:https://codesandbox.io/s/yjl1...


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


      顯式持續(xù)時間 prop

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


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


      // FadeTransition.vue


      <template>

       <transition name="fade"

                   enter-active-class="fadeIn"

                   leave-active-class="fadeOut"

                   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>

      圖片描述


      完整事例地址:https://codesandbox.io/s/j4qn...


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


      Transition group 支持

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


      // FadeTransition.vue


      <template>

       <component :is="type"

                  :tag="tag"

                  enter-active-class="fadeIn"

                  leave-active-class="fadeOut"

                  move-class="fade-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 class="box"

              v-for="(item, index) in list"

              @click="remove(index)"

              :key="item"

          >

         </div>

       </fade-transition>

      </div>


      ...

      圖片描述


      完整事例地址:https://codesandbox.io/s/pk9r...


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


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


      Vue Transition

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


      總結(jié)

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

      日歷

      鏈接

      個人資料

      藍(lán)藍(lán)設(shè)計的小編 http://www.tuitetiyu.cn

      存檔

      主站蜘蛛池模板: 国产曰韩无码亚洲视频| 精品国产免费第一区二区三区 | 玩弄丰满少妇XXXXX性多毛| 亚洲欧美日韩激情在线观看| 亚洲中文字幕乱码在线电影| 人人爽人人爽人人片AV| 久久大香香蕉国产免费网动漫| 亚洲mv国产mv在线mv综合试看| 99riav国产精品视频| 亚洲精品无码日韩国产不卡av | 末发育娇小性色XXXXX | 久久久久久亚洲| 野花日本大全免费观看| 男人扒开添女人下部免费视频| 柠檬福利精品视频导航| 正在播放国产高颜值极品美女| 亚洲精品无码视频网站| 亚洲AV无码乱码| 国产精品盗摄一区二区在线| 波多野结衣一区二区| 新国产三级在线观看播放| 国产精品爱啪在线播放| 国自产精品手机在线视频| 东方av四虎在线观看| 国产精品亚洲欧美日韩一区在线| 日本久久久久久久久性生活视频| 日本护士做XXXXX| 亚洲欧美在线中文字幕不卡 | 安福县| 亚洲欧洲美洲无码精品| 中文字无码日韩欧毛| 西西人体大胆无码视频| 亚洲sm另类一区二区三区| 中文字幕av国产精品| 久久99动作精品| 国产精品国产三级大全| 丰满人妻一区二区三区免费视频| 蜜臀AV无码精品人妻色欲| 精品国产一区二区三区香蕉| 国内精品免费久久久久电影院| 精品国产高清在线看国产毛片 |