vue_组件动画封装

复制代码
<!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>
    <fade :show="show"><h2>hello world</h2></fade>
    <fade :show="show"><div>bye world</div></fade>
    <button @click="handleClick">切换</button>
  </div>
</body>
<script type="text/javascript">
  Vue.component('fade', {
    props:['show'],
    template:`
      <transition 
        @before-enter="beforeEnter"
        @enter="enter"
        @after-enter="afterEnter"
        @before-leave="beforeLeave"
        @leave="leave"
        @after-leave="afterLeave"
      >
        <slot v-if="show"></slot>
      </transition>
    `,
    methods: {
      beforeEnter (el) {
        el.style.color = 'red'
      },
      enter (el, done) {
        setTimeout(()=> {
          el.style.color = 'green'
        },1000)
        setTimeout(()=> {
          done()
        },3000)
      },
      afterEnter (el) {
        el.style.color = 'blue'
      },
      beforeLeave (el) {
        el.style.opacity = 1
        el.style.fontSize = '16px'
      },
      leave (el, done) {
        Velocity(el, {
          opacity: 0,
          fontSize: '0px'
        },{
          duration: 1000,
          complete: done
        })
      },
      afterLeave (el) {
        console.log('动画结束')
      }
    }
  })
  let vm = new Vue({
    el: '#app',
    data: {
      show: true
    },
    methods: {
      handleClick () {
        this.show = !this.show
      }
    }
  })
</script>
</html>
复制代码

 

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