vue_动画钩子函数_使用Velocity.js

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
  <link rel="stylesheet" type="text/css" href="https://cdn.bootcss.com/animate.css/3.7.2/animate.min.css">
  <script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
  <style type="text/css">
  
  </style>
</head>
<body>
  <div id="app">
    <h3>同时使用过渡和动画</h3>
    <!-- 使用v-on绑定钩子函数 -->
    <transition 
      v-on:before-enter="beforeEnter"
      v-on:enter="enter"
      v-on:after-enter="afterEnter"
      v-on:before-leave="beforeLeave"
      v-on:leave="leave"
      v-on:after-leave="afterLeave"
    >
      <h2 v-if="show">hello world</h2>
    </transition>
    <button @click="handleClick">切换</button>
  </div>
</body>
<script type="text/javascript">

  let vm = new Vue({
    el: '#app',
    data: {
      show: true
    },
    methods: {
      // 当只用 JavaScript 过渡的时候,在 enter 和 leave 中必须使用 done 进行回调。否则,它们将被同步调用,过渡会立即完成。
      //  入场动画以前
      beforeEnter (el) {
        // el:代表transition包裹的元素
        el.style.color = 'red'
      },
      // beforeenter执行完以后执行
      // 表示进入动画
      enter (el, done) {
        setTimeout(()=>{
          el.style.color = 'green'
        },1000)
        // done()表示动画执行完成
        setTimeout(()=>{
          done()
        },3000)
      },
      // 在动画done()执行完后在指定afterEnter函数
      afterEnter (el) {
        el.style.color="black"
      },
      //离场动画
      //使用velocity.js
      beforeLeave (el) {
        el.style.opacity = 1
      },
      leave (el, done) {
        Velocity(el, {
          opacity: 0 // 过渡动画的样式
        }, {
          duration: 1000,//动画过渡时长
          complete: done //表示动画结束后自动执行done函数
        })
      },
      //done()函数执行以后自动调用afterleave函数
      afterLeave (el) {
        console.log('动画完成')
      },
      handleClick () {
        this.show = !this.show
      }
    }
  })
</script>
</html>
复制代码

 

posted @   前端之旅  阅读(292)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示