用了很多动效,介绍四个很 Nice 的 Veu 路由过渡动效

本文已经过原作者 Ahmad shaded 授权翻译。用多由过
Vue Router 过渡是动效e的渡动向Vue应用程序添加个性的一种快速简便的方法。它让我们可以在应用程序的介绍不同页面之间添加平滑的动画/过渡效果。
如果使用得当,用多由过它可以让我们的动效e的渡动应用程序更加现代和专业,从而增强用户体验。介绍
在今天的用多由过文章中,我们介绍使用Vue Router过渡的动效e的渡动基础知识,然后再介绍一些基本示例,介绍希望能给大家一些启发和灵感。用多由过
下面我们要创建的动效e的渡动四个过渡页面。

将 Vue 路由过渡添加到项目中
通常,介绍Vue路由器设置如下所示
// default template <template> <router-view /> </template>在旧版本的用多由过Vue Router中,我们可以简单地用<transition> 组件包装<router-view>。动效e的渡动
然而,介绍在Vue Router的新版本中,我们必须使用v-slot来解构我们的 props ,网站模板并将它们传递到我们的内部插槽。这个slow包含一个被transition包围的动态组件。
<router-view v-slot="{ Component }"> <transition> <component :is="Component" /> </transition> </router-view>每个 Route 都有不同的过渡
默认情况下,用 <transition> 包装<component>将在我们使用 的每条路由上添加相同的过渡。
有两种不同的方法可以为每个路由定制转场。
将过 transition 移到各个组件部分首先,我们可以将 <transition> 移到每个单独的组件中,而不是用 <transition> 组件来包装我们的动态组件。如下:
// app.vue <template> <transition> <div class="wrapper"> <!-- --> </div> </transition> </template>对于我们想要每个路由都有一个过渡效果,通过这种方式,我们可以通过过渡的名称来定制每个路由。
使用 v-bind 的动态过渡另一种方法是将过渡的名称绑定到一个变量。然后,我们可以根据监听路由动态地改变这个变量。
<transition :name="transitionName"> <component :is="Component" /> </transition> 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 – Fade Vue Router Transitions
添渐隐页面过渡可能是b2b信息网我们可以添加到Vue应用程序中最常用的动效之一。
我们可以通过更改元素的opacity 来实现此效果。
首先,我们创建一个带有fade名称的 Vue Router transition。还要注意的另一件事是,我们将过渡模式设置为 out-in。
有三种不同的过渡模式:
default – 进入和离开过渡同时发生 in-out – 新元素的过渡先进入。然后,当前元素过渡出去。 out-in - 当前元素先过渡出去。然后,新元素过渡进来。为了让新元素平滑地淡入,我们需要在开始新的过渡之前删除当前元素。所以我们使用 mode="out-in"。
<transition>为我们提供了几个CSS类,它们在动画周期中被动态添加/删除。
有6个不同的过渡类(3个用于进入,3个用于离开)。
v-enter-from:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。IT技术网 v-leave-from:定义离开过渡的开始状态。在离开过渡被触发时立刻生效,下一帧被移除。 v-enter-active:定义进入过渡生效时的状态。在整个进入过渡的阶段中应用,在元素被插入之前生效,在过渡/动画完成之后移除。这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。 v-leave-active:定义离开过渡生效时的状态。在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。 v-enter-to:定义进入过渡的结束状态。在元素被插入之后下一帧生效 (与此同时 v-enter-from 被移除),在过渡/动画完成之后移除。 v-leave-to:离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (与此同时 v-leave-from 被删除),在过渡/动画完成之后移除。注意:当我们为过渡提供一个name属性时,这是默认名称。类的格式是name-enter-from、name-enter-active,等等。
我们希望进入和离开状态的opacity 为0。然后,当我们的过渡处生效状态时,对 opacity 进行动画的处理。
// fade styles! .fade-enter-active, .fade-leave-active { transition: opacity 0.5s ease; } .fade-enter-from, .fade-leave-to { opacity: 0; }最后的效果 :

2 – Slide Vue Router Transitions
我们要构建的下一个过渡是幻灯片过渡。
模板如下所示。由于我们希望进入和离开过渡同时发生,因此使用默认模式即可。
// slide transition <router-view v-slot="{ Component }"> <transition name="slide"> <component :is="Component" /> </transition> </router-view>为了让例子更好看,我们给每个页面加上下面的样式:
// component wrapper .wrapper { width: 100%; min-height: 100vh; }最后,在过渡样式里为要滑动的组件设置相关的属性。如果需要不同的滑动方向,只需更改CSS属性(top, bottom, left, right)。
// slide styles! .slide-enter-active, .slide-leave-active { transition: all 0.75s ease-out; } .slide-enter-to { position: absolute; right: 0; } .slide-enter-from { position: absolute; right: -100%; } .slide-leave-to { position: absolute; left: -100%; } .slide-leave-from { position: absolute; left: 0; }最终的效果:

3 – Scale Vue Router Transitions
创建缩放过渡与我们的淡入过渡非常相似。我们再次将模式设置为 out-in,以便我们可以确保动画的正确顺序。
// scale transition! <router-view v-slot="{ Component }"> <transition name="scale" mode="out-in"> <component :is="Component" /> </transition> </router-view> .scale-enter-active, .scale-leave-active { transition: all 0.5s ease; } .scale-enter-from, .scale-leave-to { opacity: 0; transform: scale(0.9); }这里给整个网页提供黑色的背景色会让过渡看上去更干净。

4 – Combining Vue Router Transitions
创建过渡的方式有很多很多但是,我认为不要过度过的,刻意的去做过渡。过渡动效应该是很小的,微妙的增强功能,而不是会让应用产生干扰因素。
我认为实现较好过渡是将一些更基础的过渡结合在一起。
例如,让我们将幻灯片放大和缩小合并为一个过渡。
<router-view v-slot="{ Component }"> <transition name="scale-slide"> <component :is="Component" /> </transition> </router-view> .scale-slide-enter-active, .scale-slide-leave-active { position: absolute; transition: all 0.85s ease; } .scale-slide-enter-from { left: -100%; } .scale-slide-enter-to { left: 0%; } .scale-slide-leave-from { transform: scale(1); } .scale-slide-leave-to { transform: scale(0.8); } 
~完,我是刷碗智, 我要去刷碗了,我们下期见!
原文:https://dmitripavlutin.com/value-vs-reference-javascript/ 作者:Ahmad shaded 译者:前端小智 来源:sitepoint

相关文章
办公室路由器如何设置为主题写(以办公室路由器接路由器的设置步骤和注意事项)
摘要:在办公室中,网络连接是至关重要的。为了满足多设备同时连接的需求,有时候需要将一个路由器接到另一个路由器上。本文将介绍如何将办公室路由器设置为主题写。选择适当的设备...2025-11-04
系统上运行着诸多进程,通过jps命令能够快速有效识别 Java 进程。在 Linux 中,有一些用于查看系统上运行进程的命令。进程是指由内核管理的正在进行的事件。每启动一个应用程序时,就会产生一个进程2025-11-04
Go语言下的并发编程:Goroutine,Channel 和 Sync
优雅的并发编程范式,完善的并发支持,出色的并发性能是 Go 语言区别于其他语言的一大特色。在当今这个多核时代,并发编程的意义不言而喻。使用 Go 开发并发程序,操作起来非常简单,语言级别提供关键字 g2025-11-04
1. Pyquery的安装在使用pyquery解析库之前,首先简单介绍一下pyquery然后讲解如何安装pyquery库。pyquery的基础概念 Pyquery也是一个功能很强大的网页2025-11-04OPPOR732G全网通手机体验评测(OPPOR732G全网通手机的性能、拍照、续航等方面优势分析)
摘要:OPPOR732G全网通手机是OPPO公司推出的一款具有全网通功能的智能手机。它采用了一系列先进的技术和功能,为用户带来卓越的使用体验。本文将从性能、拍照、续航等多个方面对OPPO...2025-11-04
Sentry 监控 - Snuba 数据中台架构(Data Model 简介)
本节介绍数据在 Snuba 中的组织方式以及面向用户的数据如何映射到底层数据库(如: Clickhouse)。Snuba 数据模型横向分为逻辑模型(logical model)和物理模型(physic2025-11-04

最新评论