文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

通过示例了解Vue过渡和动画

2024-12-03 04:18

关注

 Vue过渡和动画让我们网站更具现代感并为网站访问者提供更好的用户体验的好方法。幸运的是,对于开发人员而言,Vue动画只需几分钟即可完成设置。

文本主要介绍 Vue 元素,使用该元素创建一些Vue动画,并了解将其添加到项目中的基本知识。

首先,我们来看一下 Vue Transitiont 怎么处理有条件的渲染内容。


然后,创建自己的CSS动画样式。


最后,我们将了解如何将第三方CSS库与Vue动画一起使用。


理解 Vue 过渡

虽然大多数人认为过渡只是装饰,但精心设计的过渡可以:

所有这些要点都将有助于改善我们网站的用户体验,提高转化率和用户留存率,这是双赢呀。

添加Vue过渡到我们的项目

为了适应多数的开发人员,VueJS 提供了几种实现过渡的方法:

这些方法的难度取决于你现有的知识。

元素是啥?

transition 元素是帮助我们向元素添加过渡功能的包装器。它提供了不同的钩子,并向不断变化的元素添加了类,这样我们就可以在转换的不同阶段对它们进行样式化。

将自定义库添加到代码中时,这特别有用,稍后,我们会做说明。

  1.   enter-active-class="animated fadeIn zoomIn"  
  2.   leave-active-class="animated fadeOut zoomOut" 
  3. ... 
  4.  

另外,transition元素还会发出JS钩子函数,因此我们可以捕获它们并使用 JS 来执行动画。可用的钩子有:

  1. 'beforeEnter'
  2.     -- ... --> 
  3.  

然后,我们可以在 JS 中处理它们。

  1. beforeEnter(el, done) { 
  2.    done() 

Vue Transition 高级用法

上面介绍的只是一些基础,在项目中,会遇到比较复杂的场景,这要怎么做呢?

让组件在加载下过渡

这个很简单就能实现了, 只需将appear 属性添加到transition 元素中,如下所示:

  1. name="fade" appear> 
  2. ... 
  3.  

在多个元素之间过渡

假设有两个这样交替的div。

  1. name="fade" appear> 
  2.   "visible"
  3.     Option A 
  4.   
 
  •   else
  •     Option B 
  •   
  •  
  •  
  •  我们要做的就是将它们包在transition中,这样过渡样式将同时适用于两者。

    要使代码按我们希望的方式起作用,需要注意以下几点:

    绝对定位元素

    当Vue在两个元素之间过渡时,有时会同时显示两个元素并进行进去/离开的过渡。如果要获得平滑的效果,则可能需要将它们绝对定位在彼此的顶部。

    否则,将元素添加到DOM中或从DOM中删除时,这些元素可能只是在各处跳跃。

    如果元素是一样的,则必须向该组件添加一个key属性

    如果元素是一样的,Vue 会尝试优化内容,仅替换元素的内容。根据文档,如果要在多个元素之间进行过渡,最好始终添加 key。

    更改过渡时间

    Vue 可以检测到过渡/动画何时结束,但是如果我们想设置确切的持续时间,可以通过 duration属性设置 。

    我们可以为enter和leave过渡都传递一个值,也可以传有两个值的对象。

    1. "500">...  
    2. ... 
    3. "{ enter: 1000, leave: 200 }">... 

    动态组件之间的转换

    我们要做的就是将动态组件包装在transition元素中。

    1. name="fade" appear> 
    2.      is='componentType' /> 
    3.    

    创建一个可重用的 transition 组件

    在开发过程中,尝试设计可重用组件是一个很好的习惯。

    封装一个可重用的 transition 很简单,在 transition 里放个 slot,如下所示:

    1.   

    现在,我们就不必担心将过渡样式,名称和所有内容添加到每个组件中,而只需使用此组件即可。

    目前为止,我们已经了解了 元素,现在就可以使用它来制作动画。

    建立第一个动画

    1.  
    2.  
    3.  

    接下来,我们添加一个按钮,通过切换变量的值来切换元素的显示。

    1. 'show = !show'> Toggle  

    设置了元素的条件渲染后,我们使用两个类来设置动画的样式:rotate-enter-active和rotate-leave-active,因为我们将过渡命名为rotate。

    一个技巧是让离开和进入使用相同动画,只是它们的方向相反。

    1. @keyframes rotate { 
    2.     0% { opacity: 0; transform: scale(0) rotate(-180deg); } 
    3.     100% { opacity: 1; transform: scale(1) rotate(0deg); } 
    4.  
    5. .rotate-enter-active { 
    6.     animation: rotate 0.2s; 
    7.  
    8. .rotate-leave-active { 
    9.     animation: rotate 0.2s reverse; 

    现在,切换我们的组件时,我们应该看到类似这样的内容。


    使用第三方库

    假设我们不想自己编写所有的CSS动画。有很多很棒的CSS动画库,可以很容易地将它们合并到VueJS动画中。

    在第一个示例中,我们只使用了 元素生成的默认类名,但是我们可以做的就是将这些值覆盖到我们想要的任何类中,在这种情况下,它将是CSS库中的类名。

    对于我们的示例,我们使用的[Animate.css](https://daneden.github.io/animate.css/) 这个动画库,我们只需将CDN链接添加到我们的index.html文件即可。

    1. // index.html 
    2. "stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.7.2/animate.min.css"

    现在,在我们的 元素中,我们可以使用enter-active-class和leave-active-class属性将过渡连接到Animate.js。

    1.   enter-active-class="animated fadeIn zoomIn"  
    2.   leave-active-class="animated fadeOut zoomOut" 
    3. ... 
    4.  

    超级简单,运行效果如下:


    ~完,我是前端小智,去板砖咯,我们下期见!

    作者:Matt Maribojoc 译者:前端小智 来源:stackabuse原文:https://learne.co/2020/02/vuejs-aniions-for-beginners/

     

    来源:大迁世界内容投诉

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    软考中级精品资料免费领

    • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

      难度     813人已做
      查看
    • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

      难度     354人已做
      查看
    • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

      难度     318人已做
      查看
    • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

      难度     435人已做
      查看
    • 2024年上半年系统架构设计师考试综合知识真题

      难度     224人已做
      查看

    相关文章

    发现更多好内容

    猜你喜欢

    AI推送时光机
    位置:首页-资讯-后端开发
    咦!没有更多了?去看看其它编程学习网 内容吧
    首页课程
    资料下载
    问答资讯