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>
分类:
vue3 / learn
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现