EP41 - 過渡群組

更新 發佈閱讀 5 分鐘
TransitionGroup也是在實用範例有用過,
希望內容不要在這麼多了www
太多內容真的讀過也沒太多感覺 哈

<TransitionGroup> 是一個內建的組件,旨在對渲染在列表中的元素或組件的插入、移除和順序變更進行動畫處理。

<Transition> 的差異 - Differences from <Transition>​

<TransitionGroup> 支持與 <Transition> 相同的屬性、CSS 轉場類別和 JavaScript 鉤子監聽器,但有以下差異:

  1. 預設情況下,它不會渲染包裹元素。不過,你可以使用 tag 屬性指定要渲染的元素。
  2. 轉場模式不可用,因為我們不再在互斥的元素之間進行切換。
  3. 內部的元素必須始終具有唯一的 key 屬性。
  4. CSS 轉場類別將應用於列表中的各個元素,而不是應用於組 / 容器本身。

提示:

DOM 模板中使用時,應以 <transition-group> 的形式引用。

進入 / 離開轉場 - Enter / Leave Transitions​

以下是使用 <TransitionGroup>v-for 列表應用進入 / 離開轉場的範例:

模板

<TransitionGroup name="list" tag="ul">
<li v-for="item in items" :key="item">
{{ item }}
</li>
</TransitionGroup>

CSS

.list-enter-active,
.list-leave-active {
transition: all 0.5s ease;
}
.list-enter-from,
.list-leave-to {
opacity: 0;
transform: translateX(30px);
}

移動轉場 - Move Transitions​

上述範例存在一些明顯的缺陷:當插入或移除項目時,其周圍的項目會立即「跳」到位置,而不是平滑地移動。我們可以通過添加一些額外的 CSS 規則來修正這個問題:

CSS

.list-move, /* 對移動的元素應用轉場 */
.list-enter-active,
.list-leave-active {
transition: all 0.5s ease;
}

.list-enter-from,
.list-leave-to {
opacity: 0;
transform: translateX(30px);
}

/* 確保離開的項目脫離佈局流,以便可以正確計算移動動畫。 */
.list-leave-active {
position: absolute;
}

現在效果好多了——當整個列表被打亂時,甚至可以平滑地動畫過渡。

Full example

錯開列表轉場 - Staggering List Transitions​

透過數據屬性與 JavaScript 轉場進行通信,我們還可以在列表中實現錯開的轉場。首先,我們將項目的索引渲染為 DOM 元素上的數據屬性:

模板

<TransitionGroup
tag="ul"
:css="false"
@before-enter="onBeforeEnter"
@enter="onEnter"
@leave="onLeave"
>
<li
v-for="(item, index) in computedList"
:key="item.msg"
:data-index="index"
>
{{ item.msg }}
</li>
</TransitionGroup>

然後,在 JavaScript 鉤子中,我們根據數據屬性為元素添加延遲動畫。此範例使用 GSAP 庫來執行動畫:

JavaScript

function onEnter(el, done) {
gsap.to(el, {
opacity: 1,
height: '1.6em',
delay: el.dataset.index * 0.15,
onComplete: done
})
}

Full Example in the playground

相關文件<TransitionGroup> API reference

意外地沒有這麼多內容!耶~
同時管理大量元素的動畫效果,
使用簡化結構跟一致的過渡效果還是蠻實用的 www
留言
avatar-img
留言分享你的想法!
avatar-img
卡關的人生
4會員
73內容數
分享生活趣事~
卡關的人生的其他內容
2024/11/10
Vue 提供了多種動畫技術來提升應用程式的互動性,包括基於 CSS 類別的動畫、基於狀態的動畫,以及使用監視器來動畫化數值。基於類別的動畫可通過動態添加 CSS 類別來觸發,像是觸發按鈕搖動效果。基於狀態的動畫則是透過樣式綁定,根據互動動態調整元素的外觀,例如根據滑鼠位置改變背景顏色。
Thumbnail
2024/11/10
Vue 提供了多種動畫技術來提升應用程式的互動性,包括基於 CSS 類別的動畫、基於狀態的動畫,以及使用監視器來動畫化數值。基於類別的動畫可通過動態添加 CSS 類別來觸發,像是觸發按鈕搖動效果。基於狀態的動畫則是透過樣式綁定,根據互動動態調整元素的外觀,例如根據滑鼠位置改變背景顏色。
Thumbnail
2024/11/09
Web Components 是一組網頁原生 API,允許開發者創建可重複使用的自訂元素。Vue 與 Web Components 是互補的技術,Vue 支援整合和創建自訂元素。
Thumbnail
2024/11/09
Web Components 是一組網頁原生 API,允許開發者創建可重複使用的自訂元素。Vue 與 Web Components 是互補的技術,Vue 支援整合和創建自訂元素。
Thumbnail
2024/11/08
Vue 建議使用模板構建應用程式,但在需要 JavaScript 的全程式化功能時,渲染函數可派上用場。渲染函數通過 h() 函數創建 vnode,h 是 hyperscript 的簡寫,能生成 HTML 的 JavaScript。
Thumbnail
2024/11/08
Vue 建議使用模板構建應用程式,但在需要 JavaScript 的全程式化功能時,渲染函數可派上用場。渲染函數通過 h() 函數創建 vnode,h 是 hyperscript 的簡寫,能生成 HTML 的 JavaScript。
Thumbnail
看更多
你可能也想看
Thumbnail
身為一個喜歡閱讀的人,讀書、借書、買書、送書、推書(推廣閱讀)我都做過。 大家常用的社群平台,雞蛋哥幾乎都試過在上面分享讀書心得,做過幾次錄說書影片,也曾上過廣播節目分享書籍,近期也開始嘗試錄製說書音檔,希望能讓更多的人,對閱讀開始產生興趣。 我也追蹤一些推廣閱讀的網紅、閱讀帳(會在社群固定
Thumbnail
身為一個喜歡閱讀的人,讀書、借書、買書、送書、推書(推廣閱讀)我都做過。 大家常用的社群平台,雞蛋哥幾乎都試過在上面分享讀書心得,做過幾次錄說書影片,也曾上過廣播節目分享書籍,近期也開始嘗試錄製說書音檔,希望能讓更多的人,對閱讀開始產生興趣。 我也追蹤一些推廣閱讀的網紅、閱讀帳(會在社群固定
Thumbnail
蝦皮分潤計畫的註冊流程超簡單、超方便! 想成為推廣達人,一起把興趣變成收入嗎? 【蝦皮 12.12 狂歡生日慶】 📌 全站$99起免運 📌 刷卡回饋12%起 📌 滿千現折$200 📌 品牌熱銷6折起
Thumbnail
蝦皮分潤計畫的註冊流程超簡單、超方便! 想成為推廣達人,一起把興趣變成收入嗎? 【蝦皮 12.12 狂歡生日慶】 📌 全站$99起免運 📌 刷卡回饋12%起 📌 滿千現折$200 📌 品牌熱銷6折起
Thumbnail
在 TypeScript 中,套件是模組化代碼的集合,可以提高代碼的可重用性和可維護性。常見的套件包括各種庫和框架,如 lodash、express 等。以下是有關引用套件、自定義套件和常見套件的詳細介紹。
Thumbnail
在 TypeScript 中,套件是模組化代碼的集合,可以提高代碼的可重用性和可維護性。常見的套件包括各種庫和框架,如 lodash、express 等。以下是有關引用套件、自定義套件和常見套件的詳細介紹。
Thumbnail
本章節提供了關於Typescript中流程控制元素的詳細介紹,包括if, else if, else語句,三元運算子,switch語句,各種for迴圈,while迴圈,循環嵌套和控制迴圈語句(break,continue和標籤)的使用。
Thumbnail
本章節提供了關於Typescript中流程控制元素的詳細介紹,包括if, else if, else語句,三元運算子,switch語句,各種for迴圈,while迴圈,循環嵌套和控制迴圈語句(break,continue和標籤)的使用。
Thumbnail
本章節旨在介紹 TypeScript 的基本資料型別,包括內建型別、型別轉換、自訂型別、元組、集合、陣列、和字典型別。透過理解和使用這些型別,可以提高代碼的可讀性和可維護性。
Thumbnail
本章節旨在介紹 TypeScript 的基本資料型別,包括內建型別、型別轉換、自訂型別、元組、集合、陣列、和字典型別。透過理解和使用這些型別,可以提高代碼的可讀性和可維護性。
Thumbnail
本章節旨在介紹TypeScript的基本語法,包括一般結構、程式進入點、註解以及變數的定義和賦值。這些知識將幫助讀者瞭解TypeScript的基本架構,並且可以開始使用TypeScript進行開發。
Thumbnail
本章節旨在介紹TypeScript的基本語法,包括一般結構、程式進入點、註解以及變數的定義和賦值。這些知識將幫助讀者瞭解TypeScript的基本架構,並且可以開始使用TypeScript進行開發。
Thumbnail
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
Thumbnail
我們在實作中,難免會遇到在不同組件中,卻有需求相同的資料格式,因此 mixins 可以達到我們的需求,除了 data 以外也包含了 methods 可以共用,舉例來說,學生資料可能會在,班級跟社團內被使用,當我們要撰寫元件時,就可以省略多餘的 data 定義。
追蹤感興趣的內容從 Google News 追蹤更多 vocus 的最新精選內容追蹤 Google News