[vue3]Transition过渡效果

触发条件

应用过渡和动画效果,主要基于状态变化

状态变化条件

1、v-if

2、v-show

3、动态组件 切换

4、改变属性 key

基于css的过渡效果

知识点说明

1、一般在 .v-enter-from、.v-leave-to,设置 开始点 和 结束点

2、在 .v-enter-active、.v-leave-active 设置过渡效果

过渡效果命名

知识点说明

添加 name 属性,过渡class就不是以v为前缀

举个栗子

js 复制代码
<Transition name="fade">
	...
</Transition>

.fade-enter-active,
.fade-leave-active {
    transition: all 0.5s ease;
}

.fade-enter-from,
.fade-leave-to {
    transform: translateX(100px);
    opacity: 0;
}

Transition + transition

知识点说明
<Transition> 只支持 单个元素 或 组件,作为其插槽内容,如果是组件,必须仅有一个根元素

举个栗子

js 复制代码
import { ref } from 'vue'
const isShow = ref(false)

<button @click="isShow = !isShow">{{ isShow ? '隐藏' : '显示' }}</button>

<Transition name="fade">
	<div v-if="isShow">你好,赵今麦!</div>
</Transition>

.fade-enter-active,
.fade-leave-active {
    transition: all 0.5s ease;
}

.fade-enter-from,
.fade-leave-to {
    transform: translateX(100px);
    opacity: 0;
}

Transition + animation

js 复制代码
import { ref } from 'vue'
const isShow = ref(false)

<button @click="isShow = !isShow">{{ isShow ? '隐藏' : '显示' }}</button>

<Transition name="bounce">
	<div v-if="isShow" style="text-align: center;">这是一段会跳动的文字</div>
</Transition>

@keyframes bounce-in {
    0% {
        transform: scale(0);
    }
    50% {
        transform: scale(1.25);
    }
    100% {
        transform: scale(1);
    }
}

.bounce-enter-active {
    animation: bounce-in 0.5s ease;
}
.bounce-leave-active {
    animation: bounce-in 0.5s ease reverse;
}

自定义过渡class

自定义过渡class的props

js 复制代码
enter-from-class
enter-active-class
enter-to-class
leave-from-class
leave-active-class
leave-to-class

覆盖class,在应用第三方动画库非常有用,比如 Animate.css

js 复制代码
import { ref } from 'vue'
const isShow = ref(false)

<button @click="isShow = !isShow">{{ isShow ? '隐藏' : '显示' }}</button>

<Transition
    name="custom-classes"
    enter-active-class="animate__animated animate__backInRight"
    leave-active-class="animate__animated animate__heartBeat"
>
	<div v-if="isShow">是心动的感觉啊...</div>
</Transition>

<style lang="scss" scoped>
@import "https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css";
</style>

深层级过渡与显式过渡时长

js 复制代码
<Transition
	name="nested"
	:duration="550"
	// :duration="{ enter: 500, leave: 800 }"
>
    <div v-if="show" class="outer">
        <div class="inner">
        	Hello
        </div>
    </div>
</Transition>

.nested-enter-active .inner,
.nested-leave-active .inner {
	transition: all 0.3s ease-in-out;
}
.nested-enter-active .inner {
	transition-delay: 0.25s;
}

.nested-enter-from .inner,
.nested-leave-to .inner {
    transform: translateX(30px);
    opacity: 0;
}

性能考虑

尽量使用 transform 和 opacity 属性,制作动效非常高效

优点

1、动效不影响DOM结构,css布局不会重新计算

2、大多数浏览器在执行 transform 动效时,会利用GPU进行硬件加速

绝对自律,是通往自由的唯一道路 ------ 冬泳怪鸽

相关推荐
用户51681661458414 小时前
Vue Router 路由懒加载引发的生产页面白屏问题
vue.js·vue-router
前端缘梦4 小时前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
Simon_He4 小时前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
王同学QaQ9 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
华仔啊10 小时前
基于 RuoYi-Vue 轻松实现单用户登录功能,亲测有效
java·vue.js·后端
艾小码10 小时前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密
前端·javascript·vue.js
Gracemark1 天前
高德地图-地图选择经纬度问题【使用输入提示-使用Autocomplete进行联想输入】(复盘)
vue.js
天下无贼1 天前
【手写组件】 Vue3 + Uniapp 手写一个高颜值日历组件(含跨月补全+今日高亮+选中状态)
前端·vue.js
洋葱头_1 天前
vue3项目不支持低版本的android,如何做兼容
前端·vue.js
奔跑的蜗牛ing1 天前
Vue3 + Element Plus 输入框省略号插件:零侵入式全局解决方案
vue.js·typescript·前端工程化