用了很多动效,介绍四个很 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前端

2012-05-09 12:25:55

2013-06-07 15:43:34

移动移动应用丰富动效

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

书籍翻页动效鸿蒙

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仿拉钩动效

2021-08-04 12:26:27

微软Windows 10Windows
点赞
收藏

51CTO技术栈公众号