vue从入门到学会第十天-------轻松实现过渡和动画效果

一、前言

vue虽然给我们提供了大量简化版的节点操作和组件封装,他还支持快速创建过渡效果和动画,下面一起来看看吧。

二、过渡

过渡其实本质上就是一个显示隐藏的效果,一般我们在做显示隐藏的时候我们都使用v-show,非常简单的就能实现;不过vue还给我们提供了过渡的组件供我们使用,我们可以通过这个组件来定义丰富多样的过渡效果。

1.默认过渡

在使用过渡之前,我们需要先定义一些该组件要使用到的css规则,如下;

<pre spellcheck="false" lang="cmd" cid="n38" mdtype="fences" style="margin: 15px 0px; padding: 8px 4px 6px; user-select: text !important; outline: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; overflow: visible; font-family: var(--monospace); font-size: 0.9em; break-inside: avoid; text-align: left; white-space: normal; background-image: inherit; background-position: inherit; background-size: inherit; background-repeat: inherit; background-attachment: inherit; background-origin: inherit; background-clip: inherit; background-color: rgb(248, 248, 248); border-width: 1px; border-style: solid; border-color: rgb(231, 234, 237); border-radius: 3px; width: inherit;">v-enter:定义上半场过渡的初始状态;在过渡开始前被添加,在过渡开始时会被移除
v-enter-to:定义上半场过渡的结束状态;在过渡开始时被添加,在过渡完成时会被移除
v-enter-active:这里包含了上面的v-enter、v-enter-to两个时间段,在这里可以对上半场过渡定义过渡时间、曲线等
v-leave:定义下半场过渡的初始状态;在过渡开始前被添加,在过渡开始时会被移除
v-leave-to:定义下半场过渡的结束状态;在过渡开始时被添加,在过渡完成时会被移除
v-leave-active:这里包含了上面的v-leave、v-leave-to两个时间段,在这里可以对下半场过渡定义过渡时间、曲线等</pre>

下面来看看如何制作一个过渡效果,如下:

图片

此时就实现了过渡效果。

2.具名过渡

那么问题来了,如果,过渡的效果比较多,这样肯定是不行的,毕竟每个过渡效果肯定都不会一样,因此这个时候我们需要给这些过渡效果添加一个名字,如下:

图片

此时,咱们的过渡就只能使用name开头的才能实现效果了,默认的v开头的就失去了作用,因为他只会作用在没有声明name属性的transition组件上,此时便会产生六个过渡的css规则。

3.自定义过渡类名

它是通过修改过渡的各个阶段的类来实现的,如下:

图片

由于这种方法比较麻烦,故不推荐使用,小编建议大家使用第二种。

4.过渡事件

我们不光可以通过css来控制过渡效果,还可以通过事件来控制,一般有如下事件:

<pre spellcheck="false" lang="cmd" cid="n69" mdtype="fences" style="margin: 15px 0px; padding: 8px 4px 6px; user-select: text !important; outline: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; overflow: visible; font-family: var(--monospace); font-size: 0.9em; break-inside: avoid; text-align: left; white-space: normal; background-image: inherit; background-position: inherit; background-size: inherit; background-repeat: inherit; background-attachment: inherit; background-origin: inherit; background-clip: inherit; background-color: rgb(248, 248, 248); border-width: 1px; border-style: solid; border-color: rgb(231, 234, 237); border-radius: 3px; width: inherit;">before-enter
before-leave
before-appear
enter
leave
appear
after-enter
after-leave
after-appear
enter-cancelled
leave-cancelled (v-show only)
appear-cancelled</pre>

来让我们看下这些事件的执行顺序,我们随便挑四个来看下效果,如下:

图片

5.初始化使用过渡

transition还支持初始化页面就显示过渡效果,只需要设置一个属性即可,如下:

图片

只不过使用后会有警告。

6.选择过渡模式

目前支持两种,如下:

<pre spellcheck="false" lang="cmd" cid="n93" mdtype="fences" style="margin: 15px 0px; padding: 8px 4px 6px; user-select: text !important; outline: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; overflow: visible; font-family: var(--monospace); font-size: 0.9em; break-inside: avoid; text-align: left; white-space: normal; background-image: inherit; background-position: inherit; background-size: inherit; background-repeat: inherit; background-attachment: inherit; background-origin: inherit; background-clip: inherit; background-color: rgb(248, 248, 248); border-width: 1px; border-style: solid; border-color: rgb(231, 234, 237); border-radius: 3px; width: inherit;">out-in 淡出
in-out 淡入</pre>

默认情况下两种一起进行,如下:

图片

指定模式后,该transition组件下的所有标签的显示方式都按这个模式的来。

7.过渡持续时间

如果想要过渡持续时间长点,可以修改时间,如下:

图片

其实过渡可以设置开始和结束的时间,如下:

<pre spellcheck="false" lang="cmd" cid="n124" mdtype="fences" style="margin: 15px 0px; padding: 8px 4px 6px; user-select: text !important; outline: 0px; max-width: 100%; box-sizing: border-box; overflow-wrap: break-word !important; overflow: visible; font-family: var(--monospace); font-size: 0.9em; break-inside: avoid; text-align: left; white-space: normal; background-image: inherit; background-position: inherit; background-size: inherit; background-repeat: inherit; background-attachment: inherit; background-origin: inherit; background-clip: inherit; background-color: rgb(248, 248, 248); border-width: 1px; border-style: solid; border-color: rgb(231, 234, 237); border-radius: 3px; width: inherit;">duration=“{enter:6,leave:6}”</pre>

transition不支持多个标签或者组件的存在,除非是动态组件,如果同时加载多个组件或者标签,建议使用多元素过渡。

三、多元素过渡

虽然上面的过渡组件很强大,只不过该过渡组件里面最多只能放一个标签进去,如果放多个标签或者组件的话,会出问题,除非是动态组件,因此我们需要使用多元素过渡组件,如下:

图片

四、动画

动画效果也是在过渡组件中实现的,只不过我们需要设置一些动画的帧,设置的越多越详细,动画就越丰富多彩,不过前提是你的css3的基础要够好,如下:

图片

五、总结

以上就是vue中的关于过渡和动画的全部知识了,比较简单总体来说,这玩意了解下就好了,没必要深究,后面还有很多优秀的ui框架等着我们去学习,重复造轮子不如直接拿来用现成的,本文源码获取只需关注公众号"简易编程网"并后台回复vue10即可。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容