成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

用了很多動效,介紹四個很 Nice 的 Veu 路由過渡動效

開發 前端
在今天的文章中,我們介紹使用Vue Router過渡的基礎知識,然后再介紹一些基本示例,希望能給大家一些啟發和靈感。

[[393236]]

本文已經過原作者 Ahmad shaded 授權翻譯。

Vue Router 過渡是向Vue應用程序添加個性的一種快速簡便的方法。它讓我們可以在應用程序的不同頁面之間添加平滑的動畫/過渡效果。

如果使用得當,它可以讓我們的應用程序更加現代和專業,從而增強用戶體驗。

在今天的文章中,我們介紹使用Vue Router過渡的基礎知識,然后再介紹一些基本示例,希望能給大家一些啟發和靈感。

下面我們要創建的四個過渡頁面。

圖片

將 Vue 路由過渡添加到項目中

通常,Vue路由器設置如下所示

  1. // default template 
  2. <template> 
  3.   <router-view /> 
  4. </template> 

在舊版本的Vue Router中,我們可以簡單地用<transition> 組件包裝<router-view>

然而,在Vue Router的新版本中,我們必須使用v-slot來解構我們的 props ,并將它們傳遞到我們的內部插槽。這個slow包含一個被transition包圍的動態組件。

  1. <router-view v-slot="{ Component }"
  2.   <transition> 
  3.     <component :is="Component" /> 
  4.   </transition> 
  5. </router-view

每個 Route 都有不同的過渡

默認情況下,用 <transition> 包裝<component>將在我們使用 的每條路由上添加相同的過渡。

有兩種不同的方法可以為每個路由定制轉場。

將過 transition 移到各個組件部分

首先,我們可以將 <transition> 移到每個單獨的組件中,而不是用 <transition> 組件來包裝我們的動態組件。如下:

  1. // app.vue 
  2. <template> 
  3.   <transition> 
  4.     <div class="wrapper"
  5.       <!-- --> 
  6.     </div> 
  7.   </transition> 
  8. </template> 

 對于我們想要每個路由都有一個過渡效果,通過這種方式,我們可以通過過渡的名稱來定制每個路由。

使用 v-bind 的動態過渡

另一種方法是將過渡的名稱綁定到一個變量。然后,我們可以根據監聽路由動態地改變這個變量。

  1. <transition :name="transitionName"
  2.   <component :is="Component" /> 
  3. </transition> 
  1. watch: { 
  2.   '$route' (tofrom) { 
  3.     const toDepth = to.path.split('/').length 
  4.     const fromDepth = from.path.split('/').length 
  5.     this.transitionName = toDepth < fromDepth ? 'slide-right' : 'slide-left' 
  6.   } 

現在,我們了解了Vue Router Transition 的基礎知識,下面我們來看一些 Nice 的示例。

1 – Fade Vue Router Transitions

添漸隱頁面過渡可能是我們可以添加到Vue應用程序中最常用的動效之一。

我們可以通過更改元素的opacity 來實現此效果。

首先,我們創建一個帶有fade名稱的 Vue Router transition。還要注意的另一件事是,我們將過渡模式設置為 out-in。

有三種不同的過渡模式:

  • default – 進入和離開過渡同時發生
  • in-out – 新元素的過渡先進入。然后,當前元素過渡出去。
  • out-in - 當前元素先過渡出去。然后,新元素過渡進來。

為了讓新元素平滑地淡入,我們需要在開始新的過渡之前刪除當前元素。所以我們使用 mode="out-in"。

<transition>為我們提供了幾個CSS類,它們在動畫周期中被動態添加/刪除。

有6個不同的過渡類(3個用于進入,3個用于離開)。

  1. v-enter-from:定義進入過渡的開始狀態。在元素被插入之前生效,在元素被插入之后的下一幀移除。
  2. v-leave-from:定義離開過渡的開始狀態。在離開過渡被觸發時立刻生效,下一幀被移除。
  3. v-enter-active:定義進入過渡生效時的狀態。在整個進入過渡的階段中應用,在元素被插入之前生效,在過渡/動畫完成之后移除。這個類可以被用來定義進入過渡的過程時間,延遲和曲線函數。
  4. v-leave-active:定義離開過渡生效時的狀態。在整個離開過渡的階段中應用,在離開過渡被觸發時立刻生效,在過渡/動畫完成之后移除。這個類可以被用來定義離開過渡的過程時間,延遲和曲線函數。
  5. v-enter-to:定義進入過渡的結束狀態。在元素被插入之后下一幀生效 (與此同時 v-enter-from 被移除),在過渡/動畫完成之后移除。
  6. v-leave-to:離開過渡的結束狀態。在離開過渡被觸發之后下一幀生效 (與此同時 v-leave-from 被刪除),在過渡/動畫完成之后移除。

注意:當我們為過渡提供一個name屬性時,這是默認名稱。類的格式是name-enter-from、name-enter-active,等等。

我們希望進入和離開狀態的opacity 為0。然后,當我們的過渡處生效狀態時,對 opacity 進行動畫的處理。

  1. // fade styles! 
  2. .fade-enter-active, 
  3. .fade-leave-active { 
  4.   transition: opacity 0.5s ease; 
  5.  
  6.  
  7. .fade-enter-from
  8. .fade-leave-to { 
  9.   opacity: 0; 

最后的效果 :

圖片

2 – Slide Vue Router Transitions

我們要構建的下一個過渡是幻燈片過渡。

模板如下所示。由于我們希望進入和離開過渡同時發生,因此使用默認模式即可。

  1. // slide transition 
  2. <router-view v-slot="{ Component }"
  3.   <transition name="slide"
  4.     <component :is="Component" /> 
  5.   </transition> 
  6. </router-view

為了讓例子更好看,我們給每個頁面加上下面的樣式:

  1. // component wrapper 
  2. .wrapper { 
  3.   width: 100%; 
  4.   min-height: 100vh; 

最后,在過渡樣式里為要滑動的組件設置相關的屬性。如果需要不同的滑動方向,只需更改CSS屬性(top, bottom, left, right)。

  1. // slide styles! 
  2. .slide-enter-active, 
  3. .slide-leave-active { 
  4.   transition: all 0.75s ease-out
  5.  
  6.  
  7. .slide-enter-to { 
  8.   position: absolute
  9.   right: 0; 
  10.  
  11.  
  12. .slide-enter-from { 
  13.   position: absolute
  14.   right: -100%; 
  15.  
  16.  
  17. .slide-leave-to { 
  18.   position: absolute
  19.   left: -100%; 
  20.  
  21.  
  22. .slide-leave-from { 
  23.   position: absolute
  24.   left: 0; 

最終的效果:

圖片

3 – Scale Vue Router Transitions

創建縮放過渡與我們的淡入過渡非常相似。我們再次將模式設置為 out-in,以便我們可以確保動畫的正確順序。

  1. // scale transition! 
  2.  
  3. <router-view v-slot="{ Component }"
  4.   <transition name="scale" mode="out-in"
  5.     <component :is="Component" /> 
  6.   </transition> 
  7. </router-view
  1. .scale-enter-active, 
  2. .scale-leave-active { 
  3.   transition: all 0.5s ease; 
  4.  
  5.  
  6. .scale-enter-from
  7. .scale-leave-to { 
  8.   opacity: 0; 
  9.   transform: scale(0.9); 

這里給整個網頁提供黑色的背景色會讓過渡看上去更干凈。

圖片

4 – Combining Vue Router Transitions

創建過渡的方式有很多很多但是,我認為不要過度過的,刻意的去做過渡。過渡動效應該是很小的,微妙的增強功能,而不是會讓應用產生干擾因素。

我認為實現較好過渡是將一些更基礎的過渡結合在一起。

例如,讓我們將幻燈片放大和縮小合并為一個過渡。

  1. <router-view v-slot="{ Component }"
  2.   <transition name="scale-slide"
  3.     <component :is="Component" /> 
  4.   </transition> 
  5. </router-view
  1. .scale-slide-enter-active, 
  2. .scale-slide-leave-active { 
  3.   position: absolute
  4.   transition: all 0.85s ease; 
  5.  
  6.  
  7. .scale-slide-enter-from { 
  8.   left: -100%; 
  9.  
  10.  
  11. .scale-slide-enter-to { 
  12.   left: 0%; 
  13.  
  14.  
  15. .scale-slide-leave-from { 
  16.   transform: scale(1); 
  17.  
  18.  
  19. .scale-slide-leave-to { 
  20.   transform: scale(0.8); 

 圖片

~完,我是刷碗智, 我要去刷碗了,我們下期見!

原文:https://dmitripavlutin.com/value-vs-reference-javascript/ 作者:Ahmad shaded 譯者:前端小智 來源:sitepoint

 

責任編輯:姜華 來源: 大遷世界
相關推薦

2015-07-31 11:40:36

動效Swift

2014-09-28 10:39:24

AppleWatchUI

2015-08-03 10:40:45

動效設計優勢

2019-07-24 09:00:19

谷歌Android開發者

2021-06-21 15:49:39

React動效組件

2022-03-31 07:46:17

CSS動畫技巧

2022-09-01 06:54:28

CSS前端

2013-06-07 15:43:34

移動移動應用豐富動效

2012-05-09 12:25:55

2017-03-23 10:21:57

CSS3動效庫前端

2015-08-12 10:06:12

UI動效

2022-01-26 18:46:46

Canvas煙花粒子特效

2023-06-05 15:00:13

書籍翻頁動效鴻蒙

2025-05-13 08:20:00

Vue3前端動效組件庫

2015-09-28 09:07:51

2021-03-04 06:14:03

CSS webkit-box-動效

2020-10-13 21:23:52

數據

2015-08-12 09:49:38

ui配合設計師

2013-09-23 15:01:09

英特爾凌動C2000

2017-04-07 17:00:51

Android仿拉鉤動效
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品永久免费观看 | 欧美久久久久久久 | 2020国产在线 | 成人黄色av网址 | 国产一区二区三区久久久久久久久 | 国产精品视频播放 | av一区二区三区在线观看 | 亚洲高清视频一区二区 | 国产在线第一页 | 欧洲av在线 | 日韩精品一区二区三区在线 | 人妖无码 | 国产一区精品在线 | 日韩欧美专区 | 自拍偷拍在线视频 | 国产一区二区三区 | 日日骚网 | 国产激情一区二区三区 | 一级无毛片 | 久久久国产精品一区 | 国产美女一区二区 | 一区二区三区高清 | 特级生活片 | 精品视频一区二区三区在线观看 | 国产精品久久久乱弄 | 在线亚洲免费 | 99久久精品一区二区毛片吞精 | 一级片免费视频 | 日韩一区中文字幕 | av黄色片| 特级生活片 | 国产一区二区三区四区hd | 一区二区三区精品 | 欧美一级小视频 | 成人久久18免费网站麻豆 | 日韩精品成人免费观看视频 | 天天射天天操天天干 | 青青草综合网 | 一区二区在线 | 欧美日韩1区 | 精品亚洲一区二区 |