欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue內(nèi)置組件Transition的示例詳解

 更新時(shí)間:2023年09月21日 11:03:13   作者:周周愛(ài)喝粥呀  
這篇文章主要介紹了vue內(nèi)置組件Transition的詳解,簡(jiǎn)單地說(shuō),就是當(dāng)元素發(fā)生變化,比如消失、顯示時(shí),添加動(dòng)畫(huà)讓它更自然過(guò)渡,它是vue內(nèi)置組件,不需要引入注冊(cè)就可以直接使用,本文通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

1. Transition定義

Vue 提供了兩個(gè)內(nèi)置組件,可以幫助你制作基于狀態(tài)變化的過(guò)渡和動(dòng)畫(huà): <Transition> 會(huì)在一個(gè)元素或組件進(jìn)入和離開(kāi) DOM 時(shí)應(yīng)用動(dòng)畫(huà)。 <TransitionGroup> 會(huì)在一個(gè) v-for 列表中的元素或組件被插入,移動(dòng),或移除時(shí)應(yīng)用動(dòng)畫(huà)。

簡(jiǎn)單地說(shuō),就是當(dāng)元素發(fā)生變化,比如消失、顯示時(shí),添加動(dòng)畫(huà)讓它更自然過(guò)渡。它是vue內(nèi)置組件,不需要引入注冊(cè)就可以直接使用。

在什么情況會(huì)出現(xiàn)過(guò)渡?

1. v-if 切換

2. v-show 切換

3. 動(dòng)態(tài)組件 component 切換

4. 改變特殊的 key 屬性

前幾個(gè)比較好理解,最后一個(gè)用到了 key 值變化導(dǎo)致元素強(qiáng)制更新。下面例子的key值變化,vue會(huì)認(rèn)為這里產(chǎn)生了一個(gè)新元素,之前的會(huì)被刪除,從而導(dǎo)致過(guò)渡。

<script setup>
import { ref } from 'vue'
const keyValue = ref(1)
</script>
<template>
  <button @click="() =>keyValue = Math.random()">Toggle</button>
  <Transition >
    <p :key="keyValue">hello</p>
  </Transition>
</template>
<style>
.v-enter-active,
.v-leave-active {
  transition: opacity 0.5s ease;
}
.v-enter-from,
.v-leave-to {
  opacity: 0;
}
</style>

2. 添加過(guò)渡效果

如果不給命名的話(huà),添加動(dòng)畫(huà)效果的默認(rèn)類(lèi)名前綴是 v-

v-enter-active :進(jìn)入動(dòng)畫(huà)的生效狀態(tài)

v-leave-active :離開(kāi)動(dòng)畫(huà)的生效狀態(tài)

v-enter-from :剛進(jìn)入動(dòng)畫(huà)的開(kāi)始狀態(tài)

v-leave-to 離開(kāi)動(dòng)畫(huà)時(shí)的結(jié)束狀態(tài)

v-enter-to :剛進(jìn)入動(dòng)畫(huà)的結(jié)束狀態(tài)

v-leave-from :離開(kāi)動(dòng)畫(huà)的結(jié)開(kāi)始態(tài)一般前4種用得比較多,兩個(gè)生效狀態(tài),加上進(jìn)入動(dòng)畫(huà)的開(kāi)始狀態(tài)和離開(kāi)動(dòng)畫(huà)時(shí)的結(jié)束狀態(tài)。

3. 自定義過(guò)渡類(lèi)名

通過(guò) name 可以自定義 <Transition> 的過(guò)渡類(lèi)名。

<Transition name="a">
  ...
</Transition>
.a-enter-active,
.a-leave-active {
  transition: opacity 0.5s ease;
}
.a-enter-from,
.a-leave-to {
  opacity: 0;
}

注意:里面只能有一個(gè)根組件,但使用 v-if、v-else、v-else-if 切換顯示是可以的。如果想對(duì)列表中的元素設(shè)置過(guò)渡,可以使用 <TransitionGroup >

4. 深層元素的過(guò)渡

可以給深層級(jí)的元素設(shè)置過(guò)渡效果。

<Transition name="fade">
  <div v-if="show" class="outer">
    <div class="inner">
      Hello
    </div>
  </div>
</Transition>
/* 應(yīng)用于嵌套元素的規(guī)則 */
.fade-enter-active .inner,
.fade-leave-active .inner {
  transition: all 0.3s ease-in-out;
}
.fade-enter-from .inner,
.fade-leave-to .inner {
  transform: translateX(30px);
  opacity: 0;
}

duration 屬性設(shè)置過(guò)渡持續(xù)的時(shí)間,單位是毫秒。

<Transition :duration="550">...</Transition>

5. 過(guò)渡的鉤子函數(shù)

<Transition
  @before-enter="onBeforeEnter"
  @enter="onEnter"
  @after-enter="onAfterEnter"
  @enter-cancelled="onEnterCancelled"
  @before-leave="onBeforeLeave"
  @leave="onLeave"
  @after-leave="onAfterLeave"
  @leave-cancelled="onLeaveCancelled"
>
...
<<Transition>

6. 封裝過(guò)渡效果

<!-- MyTransition.vue -->
<script>
// JavaScript 鉤子邏輯...
</script>
<template>
  <!-- 包裝內(nèi)置的 Transition 組件 -->
  <Transition
    name="my-transition"
    @enter="onEnter"
    @leave="onLeave">
    <slot></slot> <!-- 向內(nèi)傳遞插槽內(nèi)容 -->
  </Transition>
</template>
<style>
</style>

注意:該組件樣式不要添加 scoped , 不然插槽內(nèi)沒(méi)有過(guò)渡效果。

<MyTransition>
  <div v-if="show">Hello</div>
</MyTransition>

7. 過(guò)渡模式

可以設(shè)置屬性 mode out-in in-out in-out 表示當(dāng)前元素先進(jìn)行過(guò)渡,完成之后新元素過(guò)渡進(jìn)入。通常我們更多的會(huì)使用out-in,讓當(dāng)前元素先離開(kāi),然后再進(jìn)行新元素的進(jìn)入 。

到此這篇關(guān)于vue內(nèi)置組件Transition的詳解的文章就介紹到這了,更多相關(guān)vue內(nèi)置組件Transition內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue實(shí)現(xiàn)編輯器鍵盤(pán)抬起時(shí)內(nèi)容跟隨光標(biāo)距頂位置向上滾動(dòng)效果

    vue實(shí)現(xiàn)編輯器鍵盤(pán)抬起時(shí)內(nèi)容跟隨光標(biāo)距頂位置向上滾動(dòng)效果

    這篇文章主要介紹了vue實(shí)現(xiàn)編輯器鍵盤(pán)抬起時(shí)內(nèi)容跟隨光標(biāo)距頂位置向上滾動(dòng)效果,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • Vue常見(jiàn)錯(cuò)誤Error?in?mounted?hook解決辦法

    Vue常見(jiàn)錯(cuò)誤Error?in?mounted?hook解決辦法

    這篇文章主要給大家介紹了關(guān)于Vue常見(jiàn)錯(cuò)誤Error?in?mounted?hook的解決辦法,出現(xiàn)這樣的問(wèn)題,會(huì)發(fā)現(xiàn)跟聲明周期鉤子有關(guān)系,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • vue 實(shí)現(xiàn)通過(guò)vuex 存儲(chǔ)值 在不同界面使用

    vue 實(shí)現(xiàn)通過(guò)vuex 存儲(chǔ)值 在不同界面使用

    今天小編就為大家分享一篇vue 實(shí)現(xiàn)通過(guò)vuex 存儲(chǔ)值 在不同界面使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-11-11
  • 關(guān)于axios不能使用Vue.use()淺析

    關(guān)于axios不能使用Vue.use()淺析

    這篇文章主要給大家介紹了關(guān)于axios不能使用Vue.use()的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的理解和學(xué)習(xí)具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • 關(guān)于element-ui?單選框默認(rèn)值不選中的解決

    關(guān)于element-ui?單選框默認(rèn)值不選中的解決

    這篇文章主要介紹了關(guān)于element-ui?單選框默認(rèn)值不選中的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue-quill-editor實(shí)現(xiàn)圖片上傳功能

    vue-quill-editor實(shí)現(xiàn)圖片上傳功能

    這篇文章主要為大家詳細(xì)介紹了vue-quill-editor實(shí)現(xiàn)圖片上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 關(guān)于vue的列表圖片選中打鉤操作

    關(guān)于vue的列表圖片選中打鉤操作

    這篇文章主要介紹了關(guān)于vue的列表圖片選中打鉤操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-09-09
  • Vue中使用vue-count-to(數(shù)字滾動(dòng)插件)詳細(xì)教程

    Vue中使用vue-count-to(數(shù)字滾動(dòng)插件)詳細(xì)教程

    這篇文章主要給大家介紹了關(guān)于Vue中使用vue-count-to(數(shù)字滾動(dòng)插件)的相關(guān)資料,最近需要開(kāi)發(fā)一個(gè)數(shù)字滾動(dòng)效果,在網(wǎng)上找到一個(gè)關(guān)于vue-countTo的插件,覺(jué)得這個(gè)插件還不錯(cuò),需要的朋友可以參考下
    2023-09-09
  • vue讀取本地的excel文件并顯示在網(wǎng)頁(yè)上方法示例

    vue讀取本地的excel文件并顯示在網(wǎng)頁(yè)上方法示例

    這篇文章主要介紹了vue讀取本地的excel文件并顯示在網(wǎng)頁(yè)上方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • vue開(kāi)發(fā)調(diào)試神器vue-devtools使用詳解

    vue開(kāi)發(fā)調(diào)試神器vue-devtools使用詳解

    這篇文章主要為大家詳細(xì)介紹了vue開(kāi)發(fā)調(diào)試神器vue-devtools的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評(píng)論