transition生命周期配合gsap

<template>
  <div @click="flag = !flag">switch</div>
  <transition
    name="fade"
    @before-enter="beforeEnter"
    @enter="enter"
    @after-enter="afterEnter"
    @enter-cancelled="enterCancelled"
    @before-leave="beforeLeave"
    @leave="leave"
    @after-leave="afterLeave"
    @leave-cancelled="leaveCancelled">
    <div v-if="flag" class="box">Hello World</div>
  </transition>
  </template>
 
  <script setup lang='ts'>
  import { ref } from 'vue'
  import gsap from 'gsap'
  let flag = ref(true)

  // befor和after无法获取到el和done事件
  const beforeEnter = (() => {
    console.log('beforeEnter')
  })

  const enter = ((el:Element, done: Function) => {
    // console.log('enter',el,done())
    // setTimeout(() => {
    //   done() // 设置了定时器执行done,会等待定时器结束后执行done后再执行下一个生命周期
    // }, 1000);
    gsap.set(el, { x: 100, y: 100 }) // gsp用法
  })

  const afterEnter = (() => {
    console.log('afterEnter')
  })

  const enterCancelled = ((el:Element) => {
    console.log('enterCancelled',el)
  })

  const beforeLeave = (() => {
    console.log('beforeLeave')
  })

  const leave = ((el:Element, done: gsap.Callback) => {
    // console.log('leave',el,done())
    gsap.to(el, { x: 0, y: 0, onComplete: done }) // gsp用法
  })

  const afterLeave = (() => {
    console.log('afterLeave')
  })

  const leaveCancelled = ((el:Element) => {
    console.log('leaveCancelled',el)
  })


  </script>
 
  <style scoped lang='scss'>
  .box {
    width: 100px;
    height: 100px;
    background-color: red;
  }
  // 根据transition的name属性,设置动画效果
  .fade-leave-form {
    width: 0px;
    height: 0px;
  }
  .fade-enter-active {
    transition: all 1s ease;
  }
  .fade-enter-to {
    width: 200px;
    height: 200px;
  }
  .fade-leave-form {
    width: 200px;
    height: 200px;
  }
  .fade-leave-active {
    transition: all 5s ease;
  }
  .fade-leave-to {
    width: 0px;
    height: 0px;
  }
  </style>

posted on   ChoZ  阅读(5)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示