Vue_同时使用过渡和动画

在上一节我们用animate动画库,在刷新页面时没有动画

如何解决第一次就显示动画内容呢?

在transform 上加上appear 和appear-active-class

 <transition name='fade'
 appear
 enter-active-class='animated swing' 
 leave-active-class='animated flash'
 appear-active-class='animated swing'> <div v-if="cssanimate">hello css animate</div> </transition> <button @click='cssclick'>css动画</button>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

这样在第一次加载时就会显示动画。

事实上,animate动画提供的是什么动画呢?就是@keyframes的这种CSS3的动画效果。

我们也可以在动画加上transition 过渡动画效果。

<transition 
 name='fade'
 appear
 type='transition'
 enter-active-class='animated swing fade2-enter-active' 
 leave-active-class='animated flash fade2-leave-active'
 appear-active-class='animated swing'> <div v-if="cssanimate3">hello css animate3</div> </transition> <button @click='cssclick3'>css动画3</button>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

在CSS中定义过渡动画:

<style> .fade-enter,.fade-leave-to{
 opacity:0;
} .fade-enter-active,.fade-leave-active{
 transition:opacity 3s;
} </style>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

transition加上type=‘transition’的原因是,transition的过渡时长可能是3s是自己定义的,但是animate默认的过渡时长为1s,所以会有冲突,type的作用是以谁的时长为总时长

当然我们也可以自己自定义时长。

<transition 
 name='fade'
 appear
 :duration ="5000" // :duration ="{enter:5000,leave:10000}" // 更复杂的定义时长
 enter-active-class='animated swing fade2-enter-active' 
 leave-active-class='animated flash fade2-leave-active'
 appear-active-class='animated swing'> <div v-if="cssanimate3">hello css animate3</div> </transition> <button @click='cssclick3'>css动画3</button>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

如此便实现动画和过渡的效果

原文发布时间:06月30日

原文作者:_dalianmiao

本文来源CSDN博客如需转载请紧急联系作者

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue提供了过渡动画的内置支持,可以通过Vue的transition组件来实现过渡动画。在transition组件中,可以定义进入动画、离开动画过渡模式等。同时,CSS也提供了丰富的动画效果,可以通过CSS的transition属性来实现过渡动画。 下面是一个使用Vue和CSS实现过渡动画的示例: ```html <template> <div> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello, World!</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> <script> export default { data() { return { show: false }; } }; </script> ``` 在上面的示例中,我们定义了一个按钮和一个包裹着文本的transition组件。文本的显示与隐藏通过控制show属性来实现。同时,我们也定义了一个名为"fade"的transition,它定义了进入和离开动画的方式。 在CSS中,我们定义了两个类名为"fade-enter-active"和"fade-leave-active",它们分别表示进入和离开动画的状态。这里我们使用了CSS的transition属性,它指定了过渡的属性和时长。在这个例子中,我们使用opacity属性和0.5秒的时长来实现淡入淡出的效果。 同时,我们也定义了类名为"fade-enter"和"fade-leave-to",它们分别表示进入和离开动画的初始和结束状态。在这个例子中,我们将opacity属性的值设置为0,表示文本初始时是透明的,离开时也是透明的。 通过这样的方式,我们就可以使用Vue和CSS来实现过渡动画了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值