首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
第 11 章 使用动画
11.1 使用CSS 3创建动画
11.1.1 transition过渡动画
11.1.2 keyframes动画
11.2 使用JavaScript的方式实现动画效果
11.3 Vue过渡动画
11.3.1 定义过渡动画
11.3.2 设置动画过程中的监听回调
11.3.3 多个组件的过渡动画
11.3.4 列表过渡动画
11.4 实战:优化用户列表页面
第 12 章 Vue CLI工具的使用
12.1 Vue CLI工具入门
12.1.1 Vue CLI工具的安装
12.1.2 快速创建Vue项目
12.2 Vue CLI项目模板工程
12.2.1 模板工程的目录结构
12.2.2 运行Vue项目工程
12.2.3 vue-class-component库简介
12.3 在项目中使用依赖
12.4 工程构建
12.5 新一代前端构建工具Vite
12.5.1 Vite与Vue CLI
12.5.2 体验Vite构建工具
第 13 章 Element Plus基于Vue 3的UI组件库
13.1 Element Plus入门
13.1.1 Element Plus的安装与使用
13.1.2 按钮组件
13.1.3 标签组件
13.1.4 空态图与加载占位图组件
13.1.5 图片与头像组件
13.2 表单类组件
13.2.1 单选框与多选框
13.2.2 标准输入框组件
13.2.3 带推荐列表的输入框组件
13.2.4 数字输入框
13.2.5 选择列表
13.2.6 多级列表组件
13.3 开关与滑块组件
13.3.1 开关组件
13.3.2 滑块组件
13.4 选择器组件
13.4.1 时间选择器
13.4.2 日期选择器
13.4.3 颜色选择器
13.5 提示类组件
13.5.1 警告组件
13.5.2 消息提示
13.5.3 通知组件
13.6 数据承载相关组件
13.6.1 表格组件
13.6.2 导航组件
13.6.3 标签页组件
13.6.4 抽屉组件
13.6.5 布局容器组件
13.7 实战:教务系统学生表
当前位置:
首页>>
技术小册>>
TypeScript和Vue从入门到精通(四)
小册名称:TypeScript和Vue从入门到精通(四)
### 11.3 Vue 过渡动画 在Vue.js的应用开发中,过渡动画不仅是提升用户体验的关键环节,也是展示应用美感和专业性的重要手段。Vue通过内置的`<transition>`和`<transition-group>`组件,提供了强大的过渡效果支持,使得开发者能够轻松地为元素或组件的进入、离开及列表的变动添加动画效果。本章节将深入探讨Vue中的过渡动画实现方式,包括基础用法、过渡类名、CSS过渡、CSS动画、JavaScript钩子以及列表过渡等高级特性。 #### 11.3.1 过渡的基础概念 在Vue中,`<transition>`和`<transition-group>`是专门用于包裹需要应用过渡效果的元素或组件的。`<transition>`用于单个元素或组件的过渡,而`<transition-group>`则用于多个元素的列表过渡,它支持元素的动态增减和排序。 - **`<transition>`**:为包裹的元素或组件在插入、更新或移除时应用过渡效果。 - **`<transition-group>`**:是`<transition>`的一个扩展,专门用于处理多个元素的列表过渡,它要求每个子节点都有一个唯一的`key`属性。 #### 11.3.2 过渡类名 Vue会在过渡开始时,自动应用一系列类名到过渡元素上,以便你可以通过CSS来控制过渡效果。这些类名包括: - `v-enter-active`:定义进入过渡的状态。在元素被插入之后下一帧生效 (在`v-enter`之后),在`transition/animation`完成之后移除。 - `v-leave-active`:定义离开过渡的状态。在离开过渡被触发时立刻生效,下一帧移除。 - `v-enter-from`:定义进入过渡的开始状态。在元素被插入之前生效,在元素被插入之后的下一帧移除。 - `v-leave-to`:定义离开过渡的结束状态。在离开过渡被触发之后下一帧生效 (此时`v-leave-from`被移除),在`transition/animation`完成之后移除。 此外,Vue 2.1.8+ 还引入了`v-enter`和`v-leave`这两个在版本变迁中逐渐被弃用的类名,但在一些旧项目中可能仍会见到它们的身影。 #### 11.3.3 CSS过渡 使用CSS过渡实现Vue中的动画效果是最直接的方式。你只需定义好相应的过渡类名及其样式,Vue就会在适当的时机自动添加或移除这些类名。 ```html <template> <div id="app"> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter-from, .fade-leave-to { opacity: 0; } </style> ``` 在上面的例子中,当点击按钮时,`<p>`元素会以淡入淡出的效果显示或隐藏。 #### 11.3.4 CSS动画 与CSS过渡类似,你也可以使用CSS动画来实现更复杂的过渡效果。只需将`transition`属性替换为`@keyframes`定义的动画即可。 ```html <style> @keyframes bounce-in { 0% { transform: scale(0); } 100% { transform: scale(1); } } .bounce-enter-active { animation: bounce-in 0.5s; } </style> ``` 将`<transition>`的`name`属性改为`bounce`,即可应用上述动画效果。 #### 11.3.5 JavaScript钩子 除了使用CSS来定义过渡效果外,Vue还提供了JavaScript钩子,允许你在过渡的不同阶段执行JavaScript代码。这些钩子包括: - `beforeEnter(el)` - `enter(el, done)` - `afterEnter(el)` - `enterCancelled(el)` - `beforeLeave(el)` - `leave(el, done)` - `afterLeave(el)` - `leaveCancelled(el)` ```javascript <transition @before-enter="beforeEnter" @enter="enter" @leave="leave" > <!-- ... --> </transition> methods: { beforeEnter(el) { // ... }, enter(el, done) { // 使用setTimeout模拟动画延迟 setTimeout(() => { // 设置样式或执行其他逻辑 done(); // 调用done表示过渡结束 }, 500); }, leave(el, done) { // 类似enter的处理 } } ``` #### 11.3.6 列表过渡 `<transition-group>`是Vue为处理列表过渡提供的组件。它基于`<transition>`,但允许对多个元素进行过渡处理,并且要求每个子元素都有一个唯一的`key`属性,以便Vue能够追踪每个节点的身份,从而重用和重新排序现有元素。 ```html <transition-group name="list" tag="div"> <div v-for="item in items" :key="item.id" class="list-item"> {{ item.text }} </div> </transition-group> <style> .list-enter-active, .list-leave-active { transition: opacity 1s, transform 1s; } .list-enter-from, .list-leave-to { opacity: 0; transform: translateY(30px); } </style> ``` 在上面的例子中,当`items`数组发生变化时,`<div>`元素会以平滑的动画效果进入或离开列表。 #### 11.3.7 过渡模式 Vue的`<transition>`和`<transition-group>`组件还支持`mode`属性,用于控制进入和离开元素之间的过渡顺序。`mode`可以设置为`"out-in"`或`"in-out"`: - **`"out-in"`**:新元素先进行过渡,完成之后当前元素过渡离开。 - **`"in-out"`**:当前元素先过渡离开,离开完成后新元素过渡进入。 这对于控制过渡的先后顺序非常有用,尤其是在需要避免两个元素同时出现在屏幕上时。 #### 11.3.8 小结 Vue的过渡动画系统通过`<transition>`和`<transition-group>`组件,结合CSS过渡/动画以及JavaScript钩子,为开发者提供了强大而灵活的动画效果实现方式。无论是单个元素的简单过渡,还是列表的动态变化,Vue都能帮助你以优雅的方式展现元素的进出与变化,从而提升应用的用户体验和视觉美感。通过深入理解和掌握这些知识点,你将能够在Vue项目中灵活运用过渡动画,为用户带来更加流畅和吸引人的交互体验。
上一篇:
11.2 使用JavaScript的方式实现动画效果
下一篇:
11.3.1 定义过渡动画
该分类下的相关小册推荐:
Vue原理与源码解析
vue项目构建基础入门与实战
Vue3技术解密
Vue.js从入门到精通(三)
TypeScript和Vue从入门到精通(三)
Vue面试指南
VUE组件基础与实战
TypeScript和Vue从入门到精通(五)
TypeScript和Vue从入门到精通(一)
TypeScript和Vue从入门到精通(二)
Vue.js从入门到精通(二)
移动端开发指南