发布于2021-05-30 07:57 阅读(1415) 评论(0) 点赞(7) 收藏(0)
Vue过渡和动画让我们网站更具现代感并为网站访问者提供更好的用户体验的好方法。幸运的是,对于开发人员而言,Vue动画只需几分钟即可完成设置。
文本主要介绍 Vue 元素,使用该元素创建一些Vue动画,并了解将其添加到项目中的基本知识。
首先,我们来看一下 Vue Transitiont 怎么处理有条件的渲染内容。
然后,创建自己的CSS动画样式。
最后,我们将了解如何将第三方CSS库与Vue动画一起使用。
1.抓住并引导用户的注意力
2.强调重要信息
3.引导用户浏览页面
4.帮助建立更专业的品牌形象
所有这些要点都将有助于改善我们网站的用户体验,提高转化率和用户留存率,这是双赢呀。
1.css 或 动画 过渡样式
2.JS Hook 对 DOM 进行编辑
3.集成第三方CSS
这些方法的难度取决于你现有的知识。
transition 元素是帮助我们向元素添加过渡功能的包装器。它提供了不同的钩子,并向不断变化的元素添加了类,这样我们就可以在转换的不同阶段对它们进行样式化。
对于这些在过渡中切换的类名来说,如果你使用一个没有名字的 ,则 v- 是这些类名的默认前缀。如果你使用了 ,那么 v-enter 会替换为 my-transition-enter。
v-enter-active 和 v-leave-active 可以控制进入/离开过渡的不同的缓和曲线,
将自定义库添加到代码中时,这特别有用,稍后,我们会做说明。
<transition
enter-active-class="animated fadeIn zoomIn"
leave-active-class="animated fadeOut zoomOut"
>
...
</transition>
1.before-enter / before-leave
2.enter / leave
3.after-enter / after-leave
4.enter-cancelled / leave-cancelled
<transition @before-enter='beforeEnter'>
<!-- ... -->
</transition>
然后,我们可以在 JS 中处理它们。
beforeEnter(el, done) {
done()
}
上面介绍的只是一些基础,在项目中,会遇到比较复杂的场景,这要怎么做呢?
这个很简单就能实现了, 只需将appear 属性添加到transition 元素中,如下所示:
<transition name="fade" appear>
...
</transition>
假设有两个这样交替的div。
<transition name="fade" appear>
<div v-if="visible">
Option A
</div>
<div v-else>
Option B
</div>
</transition>
我们要做的就是将它们包在transition中,这样过渡样式将同时适用于两者。
要使代码按我们希望的方式起作用,需要注意以下几点:
1.绝对定位元素
当Vue在两个元素之间过渡时,有时会同时显示两个元素并进行进去/离开的过渡。如果要获得平滑的效果,则可能需要将它们绝对定位在彼此的顶部。
否则,将元素添加到DOM中或从DOM中删除时,这些元素可能只是在各处跳跃。
2.如果元素是一样的,则必须向该组件添加一个key属性
如果元素是一样的,Vue 会尝试优化内容,仅替换元素的内容。根据文档,如果要在多个元素之间进行过渡,最好始终添加 key。
Vue 可以检测到过渡/动画何时结束,但是如果我们想设置确切的持续时间,可以通过 duration属性设置 。
我们可以为enter和leave过渡都传递一个值,也可以传有两个值的对象。
<transition :duration="500">...</transition>
...
<transition :duration="{ enter: 1000, leave: 200 }">...</transition>
我们要做的就是将动态组件包装在transition元素中。
<transition name="fade" appear>
<component :is='componentType' />
</transition>
在开发过程中,尝试设计可重用组件是一个很好的习惯。
封装一个可重用的 transition 很简单,在 transition 里放个 slot,如下所示:
<template>
<transition name="fade" appear>
<slot></slot>
</transition>
</template>
现在,我们就不必担心将过渡样式,名称和所有内容添加到每个组件中,而只需使用此组件即可。
目前为止,我们已经了解了元素,现在就可以使用它来制作动画。
<template>
<div class='main-content'>
<transition name='rotate'>
<img
v-if='show'
src='../img/logo.png'
>
</transition>
</div>
</template>
<script>
export default {
data () {
return {
show: true
}
}
}
</script>
接下来,我们添加一个按钮,通过切换变量的值来切换元素的显示。
<button @click='show = !show'> Toggle </button>
设置了元素的条件渲染后,我们使用两个类来设置动画的样式:rotate-enter-active和rotate-leave-active,因为我们将过渡命名为rotate。
一个技巧是让离开和进入使用相同动画,只是它们的方向相反。
@keyframes rotate {
0% { opacity: 0; transform: scale(0) rotate(-180deg); }
100% { opacity: 1; transform: scale(1) rotate(0deg); }
}
.rotate-enter-active {
animation: rotate 0.2s;
}
.rotate-leave-active {
animation: rotate 0.2s reverse;
}
现在,切换我们的组件时,我们应该看到类似这样的内容。
假设我们不想自己编写所有的CSS动画。有很多很棒的CSS动画库,可以很容易地将它们合并到VueJS动画中。
在第一个示例中,我们只使用了元素生成的默认类名,但是我们可以做的就是将这些值覆盖到我们想要的任何类中,在这种情况下,它将是CSS库中的类名。
对于我们的示例,我们使用的**Animate.css** 这个动画库,我们只需将CDN链接添加到我们的index.html文件即可。
// index.html
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/aja
现在,在我们的**元素中,我们可以使用enter-active-class和leave-active-class属性将过渡连接到Animate.js**。
<transition
enter-active-class="animated fadeIn zoomIn"
leave-active-class="animated fadeOut zoomOut"
>
...
</transition>
超级简单,运行效果如下:
原文链接:https://blog.csdn.net/weixin_50313248/article/details/117354036
作者:大师兄
链接:http://www.qianduanheidong.com/blog/article/115827/e49f7ee69b39a008d474/
来源:前端黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 前端黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-3
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!