Vue动画效果

1.哪些元素/那些组件适合在那些条件下实现动画效果
- 条件渲染 (使用 v-if)
- 条件展示 (使用 v-show)
- 动态组件
- 组件根节点
简单经典例子:(文字隐藏到显示效果)
<div>  <button @click="show = !show">show toggle</button>
  <transition name="fade">  //fade 自定义名称
    <p v-if="show">hello</p>
  </transition>
</div>
<style>
.fade-enter-active{     
  transition: opacity .5s;      //类名:隐藏到显示过程所需要的时间
}
.fade-enter {           // 类名:初始化状态
  opacity: 0;
}
</style>
复制代码
自己画了一个过渡动画生命周期,表示:动画开始,过程,结束,类名生效和失效
隐藏到显示,显示到隐藏过程
css动画
<div>  <button @click="show = !show">show toggle</button>
  <transition name="fade">  //fade 自定义名称
    <p v-if="show">hello</p>
  </transition>
</div>
<style>
.fade-enter-active {        //类名:隐藏到显示过程所需要的时间
  animation: bounce-in .5s;
}
.fade-leave-active {        //类名:显示到隐藏过程所需要的时间
  animation: bounce-in .5s reverse;     //reverse表示和隐藏到显示动画相反
}
@keyframes bounce-in {
  0% {
    transform: scale(0);
  }
  50% {
    transform: scale(1.5);
  }
  100% {
    transform: scale(1);
  }
}
</style>
复制代码
我们也可以自定义类名
<div>  <button @click="show = !show">show toggle</button>
  <transition enter-class="fadeEnter" enter-active-class="fadeActive" >  //fade 自定义名称
    <p v-if="show">hello</p>
  </transition>
</div>
<style>
.fadeActive{     
  transition: opacity .5s;      //类名:隐藏到显示过程所需要的时间
}
.fadeEnter {           // 类名:初始化状态
  opacity: 0;
}
</style>
复制代码
学到这里,我们其实也可以可以引用第三方库来实现这效果,Animate.css
// 在index.html文件下引入Animate.css<link href="https://cdn.jsdelivr.net/npm/animate.css@3.5.1" rel="stylesheet" type="text/css">
// 在组件内
<div>
  <button @click="show = !show">show toggle</button>
  <transition  
    enter-active-class="animated tada"
    leave-active-class="animated bounceOutRight" >
    <p v-if="show">hello</p>
  </transition>
</div>
以上是 Vue动画效果 的全部内容, 来源链接: utcz.com/z/380817.html








