Vue封装的过度与动画(transition-group、animate.css)

news2024/12/25 9:02:48

目录

  • 1. Vue封装的过度与动画
    • 1.1 动画效果1
    • 1.2 动态效果2
    • 1.3 使用第三方动画库animate.css

1. Vue封装的过度与动画

作用:在插入、更新或移除DOM元素时,在合适的时候给元素添加样式类名

1.1 动画效果1

Test1.vue:

  • transition内部只能包含一个子标签。包裹要过渡的元素。基本原理是Vue会在合适的时候自动给子标签添加不同的class样式属性
  • 使用了name属性就可以分别控制多个动画了
  • appear属性第一次显示的时候就有动画效果。相当于:appear="true"
<template>
	<div>
		<button @click="isShow = !isShow">显示/隐藏</button>
		<transition name="trans1" appear>
			<h1 v-show="isShow">你好啊</h1>
		</transition>
	</div>
</template>

<script>
	export default {
		name:'Test1',
		data() {
			return {
				isShow:true
			}
		}
	}
</script>

<style scoped>
	h1{
		background-color: orange;
	}

    <!-- 元素进入过程中 -->
	.trans1-enter-active{
		animation: myFlash 0.5s linear;
	}

    <!-- 元素离开过程中 -->
	.trans1-leave-active{
		animation: myFlash 0.5s linear reverse;
	}

    <!-- 准备的动画 -->
	@keyframes myFlash {
		from{
			transform: translateX(-100%);
		}
		to{
			transform: translateX(0px);
		}
	}
</style>

动画效果静态时如下:
动画效果1

1.2 动态效果2

Test2.vue:

  • 有多个元素需要过度,可以使用<transition-group>,且每个元素都要指定key值
<template>
	<div>
		<button @click="isShow = !isShow">显示/隐藏</button>
		<transition-group name="trans1" appear>
			<h1 v-show="!isShow" key="1">你好啊</h1>
			<h1 v-show="isShow" key="2">jack</h1>
		</transition-group>
	</div>
</template>

<script>
	export default {
		name:'Test2',
		data() {
			return {
				isShow:true
			}
		}
	}
</script>

<style scoped>
	h1{
		background-color: orange;
	}
	/* 进入的起点、离开的终点 */
	.trans1-enter,.trans1-leave-to{
		transform: translateX(-100%);
	}
  /* 进入的终点、离开的起点 */
  .trans1-enter-to,.trans1-leave{
    transform: translateX(0);
  }
	.trans1-enter-active,.trans1-leave-active{
		transition: 0.5s linear;
	}
</style>

动画效果静态时如下:
动画效果2

1.3 使用第三方动画库animate.css

使用cnpm install animate.css安装第三方动画库。想要更多可以去https://www.npmjs.com/进行搜索。还要另外两种方式引入animate.css文件

  1. 直接下载animate.css文件,放到src/assets/css路径下,然后通过import ./assets/css/animate.css进行引入
  2. 直接下载animate.css文件,放到public/css路径下,然后在index.html页面中通过<style rel="stylesheet" href="<%= BASE_URL %>css/animate.css"></style>进行引入

Test3.vue:直接在transition-group指定属性就可以了。指定的属性可以去https://animate.style/官网去查看

<template>
	<div>
		<button @click="isShow = !isShow">显示/隐藏</button>
		<transition-group 
			appear
			name="animate__animated animate__bounce" 
			enter-active-class="animate__swing"
			leave-active-class="animate__backOutUp"
		>
			<h1 v-show="!isShow" key="1">你好啊</h1>
			<h1 v-show="isShow" key="2">jack</h1>
		</transition-group>
	</div>
</template>

<script>
	import 'animate.css'
	export default {
		name:'Test3',
		data() {
			return {
				isShow:true
			}
		}
	}
</script>

<style scoped>
	h1{
		background-color: orange;
	}
	

</style>

动画效果静态时如下:
动画效果3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2106222.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电脑知识:如何恢复 Word、媒体和存档文件?

如果您是 Word 用户&#xff0c;那么您一定对无法打开 Word 文档的问题很熟悉。当文档包含大量关键信息时&#xff0c;情况会变得更加复杂。如果您遇到这种情况&#xff0c;那么您将如何处理&#xff1f; 我们再怎么强调在外部存储位置&#xff08;如外部硬盘、网络位置&#…

Ubuntu设置

1.查看版本:lsb_release -a 2.配置相关参数 配置root用户 设置 root 用户的登录密码&#xff0c;然后 su 登录。 1.改root密码&#xff1a;sudo passwd root 2.切换登录root用户&#xff1a; su root 3.root主目录在&#xff1a;cd ~ 4.开启 root 用户SSH远程登录权限 …

学习记录——day43 C++ 异常处理

一、异常处理的格式 1、在可能产生异常的地方使用关键字&#xff1a;throw 抛出异常 2、try { 可能会抛出异常的语句 }catch(接收异常的形参) { 处理异常 } 任何函数在定义时&#xff0c;可以指定能抛出的异常格式如下 返回值类型 函数…

前端:HTML、CSS、JS、Vue

1 前端 内容概要 了解前端三件套(HTML、CSS、JS)在前端所起的作用掌握HTML标签的功能&#xff0c;掌握重要标签(a标签&#xff0c;form标签)了解CSS了解JS的基础语法掌握Vue的基础语法重点掌握Vue项目怎么启动项目掌握前后端分离是什么。前端做什么事情&#xff0c;后端做什么…

统信UOS:快速修改主机名和计算机名

统信UOS&#xff1a;快速修改主机名和计算机名 1、修改主机名2、更改计算机显示名称 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 1、修改主机名 打开终端并获取root权限&#xff1a; 右键桌面空白处&#xff0c;选择“在终端中打开”。输…

制造业疲软引震荡,就业数据成市场焦点

周二&#xff0c;标普全球制造业PMI终值数据揭示了制造业的疲软态势&#xff0c;这一消息迅速在金融市场引发连锁反应&#xff0c;各类资产价格大幅跳水&#xff0c;交易员对经济前景的担忧情绪显著升温。在此背景下&#xff0c;即将于周五发布的美国非农就业数据无疑成为了本周…

软考 -- 软件设计师 -- 二轮复习(2) -- 程序设计语言(持续更新)

软考 – 软件设计师 – 二轮复习(2) – 程序设计语言(持续更新) 文章目录 软考 -- 软件设计师 -- 二轮复习(2) -- 程序设计语言(持续更新)前言一、编译、解释、基本控制结构二、数据类型三、变量和常量、逻辑表达式(短路&#xff1a;&&、||、&#xff01;)四、传值调用…

shell脚本编写之test命令

test命令用于测试某个条件是否成立&#xff0c;它可以进行数值、字符和文件三个方面的测试。 在shell文件中输入命令&#xff0c;通过特定的参数可以对数值、字符串进行比较&#xff0c;如下参数及示例。 1、数值比较参数 举例&#xff0c;在myshell.sh脚本中加入如下内容&am…

Github 2024-09-01 开源项目月报 Top16

根据Github Trendings的统计,本月(2024-09-01统计)共有16个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Python项目9TypeScript项目5Dart项目2C项目1Jupyter Notebook项目1Rust项目1开发者职业成长指南 创建周期:2670 天开发语言:TypeScript协议类…

图像去噪:基于混合噪声处理的 UNF 滤波器与中值滤波器比较

在图像处理领域&#xff0c;去噪是一个非常重要的步骤。噪声会严重影响图像的质量&#xff0c;使得图像难以被理解或分析。本文将演示如何使用混合噪声处理技术和两种常见的滤波器&#xff08;UNF 滤波器与中值滤波器&#xff09;来去除图像中的噪声&#xff0c;并比较它们的性…

Bootstrap前端框架Glyphicons字体图标

115工具网收集提供Bootstrap前端框架Glyphicons字体图标库对照表​​​​​​​&#xff0c;Bootstrap前端UI,Glyphicons字体图标调用,Bootstrap按钮字体图标对照表,包括250多个来自Glyphicon Halflings的字体图标.项目中引用Bootstrap相关文件后即可直接调用下列图标class&quo…

51单片机-DS1302(RTC实时时钟芯片)

数据手册在主页资源免费贡献 开发板芯片数据手册 https://www.alipan.com/s/nnkdHhMGjrz 提取码: 95ik 点击链接保存&#xff0c;

免费无广的多端同步标签 | 极空间私有化部署高颜值浏览器新标签页『mTab』

免费无广的多端同步标签 | 极空间私有化部署高颜值浏览器新标签页『mTab』 哈喽小伙伴们好&#xff0c;我是Stark-C~ 我们在日常使用浏览器的时候&#xff0c;必定收藏了很多书签或者网页程序之类。但是你是否有这样的苦恼&#xff1f;就是如何在不同设备之间&#xff0c;甚至…

GIS十大经典问题之10.网络分析中的连通性问题

本系列《GIS十大经典问题》包括&#xff1a; 缓冲区分析问题叠加分析问题最短路径分析问题空间插值问题泰森多边形&#xff08;Voronoi 图&#xff09;生成问题空间聚类问题空间数据压缩问题空间查询问题地形分析问题网络分析中的连通性问题 一、连通性问题介绍 在地理信息系…

以太网通信之UDP

免责声明&#xff1a; 本文所提供的信息和内容仅供参考。作者对本文内容的准确性、完整性、及时性或适用性不作任何明示或暗示的保证。在任何情况下&#xff0c;作者不对因使用本文内容而导致的任何直接或间接损失承担责任&#xff0c;包括但不限于数据丢失、业务中断或其他经济…

使用堆叠 LSTM 模型预测市场趋势

作者:老余捞鱼 原创不易,转载请标明出处及原作者。 写在前面的话: 本文主要介绍预测市场趋势的一种研究方法,这一研究的重点是利用堆栈式长短期记忆(LSTM)网络预测股票价格。这种方法利用先进的神经网络架构,根据历史价格数据分析和预测市场趋势。并展示了如何通…

图像边缘检测技术详解:利用OpenCV实现Sobel算子

图像边缘检测技术详解&#xff1a;利用OpenCV实现Sobel算子 前言Sobel算子的原理代码演示结果展示结语 前言 在数字图像处理的广阔领域中&#xff0c;边缘检测技术扮演着至关重要的角色。无论是在科学研究、工业自动化&#xff0c;还是在日常生活中的智能设备中&#xff0c;我们…

出现 TypeError: Cannot read properties of undefined (reading ‘getUserMedia‘) 解决方法

目录 1. 问题所示2. 原理分析3. 解决方法1. 问题所示 调用摄像头的时候出现如下所示: Uncauht (in promise) TypeError: Cannot read properties of undefined (reading getUserMedia)截图如下: 2. 原理分析 TypeError: Cannot read properties of undefined (reading ‘…

Mysql梳理1——数据库概述(上)

笔记来源&#xff1a;【MySQL数据库入门到大牛&#xff0c;mysql安装到优化&#xff0c;百科全书级&#xff0c;全网天花板】 https://www.bilibili.com/video/BV1iq4y1u7vj 目录 11.2 引入 11.2. 1 数据库与数据库管理系统 11.2.2 数据库与数据库管理系统的关系 11.2.…

【Python】4.基础语法(4)列表和元组

文章目录 1. 列表是什么, 元组是什么2. 创建列表3. 访问下标4. 切片操作5. 遍历列表元素6. 新增元素7. 查找元素8. 删除元素9. 连接列表10. 关于元组 1. 列表是什么, 元组是什么 编程中, 经常需要使用变量, 来保存/表示数据。 如果代码中需要表示的数据个数比较少, 我们直接创…