4个很 Nice 的Vue Router过渡动效,快来收藏!


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章给大家介绍4个很 Nice 的 Veu 路由过渡动效。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

Vue Router 过渡是向Vue应用程序添加个性的一种快速简便的方法。 它让我们可以在应用程序的不同页面之间添加平滑的动画/过渡效果。

如果使用得当,它可以让我们的应用程序更加现代和专业,从而增强用户体验。

在今天的文章中,我们介绍使用Vue Router过渡的基础知识,然后再介绍一些基本示例,希望能给大家一些启发和灵感。

下面我们要创建的四个过渡页面。

1.gif

将 Vue 路由过渡添加到项目中

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

1

2

3

4

// default template

<template>

  <router-view />

</template>

在旧版本的Vue Router中,我们可以简单地用<transition>组件包装<router-view>

然而,在Vue Router的新版本中,我们必须使用v-slot来解构我们的 props ,并将它们传递到我们的内部插槽。这个slow包含一个被transition包围的动态组件。

1

2

3

4

5

<router-view v-slot="{ Component }">

  <transition>

    <component :is="Component" />

  </transition>

</router-view>

每个 Route 都有不同的过渡

默认情况下,用<transition>包装<component>将在我们使用的每条路由上添加相同的过渡。

有两种不同的方法可以为每个路由定制转场。

将过 transition 移到各个组件部分

首先,我们可以将<transition>移到每个单独的组件中,而不是用<transition>组件来包装我们的动态组件。 如下:

1

2

3

4

5

6

7

8

// app.vue

<template>

  <transition>

    <div class="wrapper">

      <!-- -->

    </div>

  </transition>

</template>

对于我们想要每个路由都有一个过渡效果,通过这种方式,我们可以通过过渡的名称来定制每个路由。

使用 v-bind 的动态过渡

另一种方法是将过渡的名称绑定到一个变量。然后,我们可以根据监听路由动态地改变这个变量。

1

2

3

<transition :name="transitionName">

  <component :is="Component" />

</transition>

1

2

3

4

5

6

7

watch: {

  '$route' (to, from) {

    const toDepth = to.path.split('/').length

    const fromDepth = from.path.split('/').length

    this.transitionName = toDepth < fromDepth ? 'slide-right' : 'slide-left'

  }

}

现在,我们了解了Vue Router Transition 的基础知识,下面我们来看一些 Nice 的示例。

1 ?C Fade Vue Router Transitions

添渐隐页面过渡可能是我们可以添加到Vue应用程序中最常用的动效之一。

我们可以通过更改元素的opacity 来实现此效果。

首先,我们创建一个带有fade名称的 Vue Router transition。 还要注意的另一件事是,我们将过渡模式设置为 out-in

有三种不同的过渡模式:

  • default ?C 进入和离开过渡同时发生
  • in-out ?C 新元素的过渡先进入。然后,当前元素过渡出去。
  • out-in - 当前元素先过渡出去。然后,新元素过渡进来。

为了让新元素平滑地淡入,我们需要在开始新的过渡之前删除当前元素。所以我们使用 mode="out-in"

<transition>为我们提供了几个CSS类,它们在动画周期中被动态添加/删除。

有6个不同的过渡类(3个用于进入,3个用于离开)。

  • v-enter-from:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。

  • v-leave-from:定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。

  • v-enter-active:定义进入过渡生效时的状态。在整个进入过渡的阶段中应用,在元素被插入之前生效,在过渡/动画完成之后移除。这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。

  • v-leave-active:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。

  • v-enter-to:定义进入过渡的结束状态。在元素被插入之后下一帧生效 (与此同时 v-enter-from 被移除),在过渡/动画完成之后移除。

  • v-leave-to:离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时 v-leave-from 被删除),在过渡/动画完成之后移除。

注意:当我们为过渡提供一个name属性时,这是默认名称。类的格式是name-enter-fromname-enter-active,等等。

我们希望进入和离开状态的opacity 为0。然后,当我们的过渡处生效状态时,对 opacity 进行动画的处理。

1

2

3

4

5

6

7

8

9

10

11

// fade styles!

.fade-enter-active,

.fade-leave-active {

  transition: opacity 0.5s ease;

}

 

 

.fade-enter-from,

.fade-leave-to {

  opacity: 0;

}

最后的效果 :

2.gif

2 ?C Slide Vue Router Transitions

我们要构建的下一个过渡是幻灯片过渡。

阅读剩余部分

相关阅读 >>

vue.js需要什么基础?

vue中如何正确强制组件重新渲染?(方法介绍)

vue.js中如何获取url的值

15个vue.js高级面试问题

vue.js支持ie8吗

vue和js区别是什么

vue的$router是什么

vue.js如何声明全局变量

vue-cli3.0安装与配置的方法教程(图文)

vue.js如何做到seo

更多相关阅读请进入《vue》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...