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

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

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

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

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

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

立即学习“前端免费学习笔记(深入)”;

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

1.gif

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

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

// default template  

登录后复制

在旧版本的Vue Router中,我们可以简单地用组件包装。

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

        

登录后复制登录后复制

每个 Route 都有不同的过渡

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

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

将过 transition 移到各个组件部分

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

// app.vue      
          
  

登录后复制

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

使用 v-bind 的动态过渡

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

  

登录后复制

watch: {  '$route' (to, from) {    const toDepth = to.path.split('/').length    const fromDepth = from.path.split('/').length    this.transitionName = toDepth 

现在,我们了解了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”。

为我们提供了几个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-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.gif

2 – Slide Vue Router Transitions

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

模板如下所示。 由于我们希望进入和离开过渡同时发生,因此使用默认模式即可。

// slide transition        

登录后复制

为了让例子更好看,我们给每个页面加上下面的样式:

// 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.gif

3 – Scale Vue Router Transitions

创建缩放过渡与我们的淡入过渡非常相似。 我们再次将模式设置为 out-in,以便我们可以确保动画的正确顺序。

// scale transition!        

登录后复制

.scale-enter-active,.scale-leave-active {  transition: all 0.5s ease;}.scale-enter-from,.scale-leave-to {  opacity: 0;  transform: scale(0.9);}

登录后复制

这里给整个网页提供黑色的背景色会让过渡看上去更干净。

4.gif

4 – Combining Vue Router Transitions

创建过渡的方式有很多很多但是,我认为不要过度过的,刻意的去做过渡。 过渡动效应该是很小的,微妙的增强功能,而不是会让应用产生干扰因素。

我认为实现较好过渡是将一些更基础的过渡结合在一起。

例如,让我们将幻灯片放大和缩小合并为一个过渡。

        

登录后复制登录后复制

.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);}

登录后复制

5.gif

原文地址:https://learnue.co/2021/01/4-awesome-of-vue-router-transitions/作者:Ahmad shaded译文地址:https://segmentfault.com/a/1190000039802609

更多编程相关知识,请访问:编程视频!!

以上就是4个很 Nice 的Vue Router过渡动效,快来收藏!的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/3020249.html

(0)
上一篇 2025年3月13日 05:35:22
下一篇 2025年3月8日 12:18:55

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 一文带你看看Vue Router4中的酷炫功能

    本篇文章和大家一下了解下vue router4中的酷炫功能。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 Vue Router 4 已经发布了,我们来看看新版本中有哪些很酷的特性。【相关推荐:《vue.js教程》】 Vu…

    2025年3月13日
    200
  • 什么是Vuex?Vuex 4初学者指南

    本篇文章带大家了解一下vuex,介绍一下如何在应用程序中使用 vuex。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 Vuex 是 Vue.js 生态系统中必不可少的工具。但是新接触 Vuex 的开发人员可能会被诸如“状…

    2025年3月13日
    200
  • Vue如何进行事件处理?相关基础知识介绍

    本篇文章给大家介绍一下vue事件处理的基础知识。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 Vue事件处理是每个Vue项目的必要方面。 它用于捕获用户输入,共享数据以及许多其他创造性方式。【相关推荐:《vue.js教程…

    2025年3月13日
    200
  • 深入了解vue.js的3种安装方法

    本篇文章给大家介绍一下三种 Vue.js 的安装方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 vue.js(读音 /vjuː/, 类似于 view)是一个构建数据驱动的 web 界面的渐进式框架。vue.js 的目…

    2025年3月13日 编程技术
    200
  • 深入浅析vue3中的custom renderer特性

    本篇文章带大家一起来了解一下vue3的新特性custom renderer。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 【相关推荐:《vue.js教程》】 默认的目标渲染平台 在vue3中允许用户自定义目标渲染平台,以…

    2025年3月13日 编程技术
    200
  • Vue如何封装Echarts图表

    在开始之前,我们先按照正常的组件注册流程,在项目components目录中新建一个名为radar-chart的组件,然后在一个demo页面引入该组件使用。 新建的 radar-chart 组件内容: // radar-chart.vue (…

    2025年3月13日
    200
  • 浅谈Vue中v-for,key取值影响过渡效果和动画效果(代码详解)

    之前的文章《教你怎么使用Vue实现动画效果(附代码)》中,给大家介绍了怎么使用Vue实现动画效果。下面本篇文章给大家了解一下浅谈Vue中key取值影响过渡效果和动画效果,有需要的朋友可以参考一下,希望对你们有帮助。 关于Vue.js的v-f…

    2025年3月13日
    200
  • 浅析Vue中入口缓存的问题(代码分享)

    之前的文章《你值得了解的HTTP缓存机制(代码详解)》中,给大家了解了HTTP缓存机制。下面本篇文章给大家了解Vue中入口缓存的问题,伙伴们来看看吧。 关于web的缓存策略,推荐这篇文章:Http缓存机制 在开发时候经常遇到一个问题,我们根…

    2025年3月13日
    200
  • 怎么看vuejs是否安装成功

    看vuejs是否安装成功的方法:1、使用组合键“windows+R”打开“运行”窗口,输入“cmd”,点击“确定”;2、在打开的cmd命令窗口中,执行命令“vue -V”,如果输出版本号则表示vuejs安装成功,反之则安装不成功。 本教程操…

    2025年3月13日
    200
  • vuejs怎么关闭弹窗

    vuejs关闭弹窗的方法:1、创建html代码结构;2、判断所点击的区域是否在“.mask_popup”中;3、通过“hideMaskPopup(e){…}”关闭弹窗即可。 本文操作环境:windows7系统、vue2.5.17…

    2025年3月13日
    200

发表回复

登录后才能评论