Vue-49、Vue技术实现动画效果

1、首先,在Vue项目中的src/components文件夹下创建一个名为AnimatedBox.vue的文件。
2、编辑AnimatedBox.vue文件,添加以下代码:

<template><div class="animated-box" @click="toggle"><transition name="fade"><div v-if="isVisible" class="box"></div></transition></div>
</template><script>
export default {data() {return {isVisible: true,};},methods: {toggle() {this.isVisible = !this.isVisible;},},
};
</script><style scoped>
.animated-box {width: 100px;height: 100px;background-color: lightblue;position: relative;
}.box {width: 50px;height: 50px;background-color: red;position: absolute;top: 25px;left: 25px;
}.fade-enter-active,
.fade-leave-active {transition: opacity 0.5s;
}
.fade-enter,
.fade-leave-to {opacity: 0;
}
</style>

在这个示例中,我们创建了一个名为AnimatedBox的Vue组件。当用户点击这个组件时,它会切换isVisible数据属性的值,从而触发动画效果。我们使用组件包裹

元素,并为其添加一个名为fade的过渡类。然后,我们在

3、最后,在需要使用AnimatedBox组件的地方引入它,例如在App.vue文件中:

<template><div id="app"><AnimatedBox /></div>
</template><script>
import AnimatedBox from './components/AnimatedBox.vue';export default {components: {AnimatedBox,},
};
</script>

现在,当你点击AnimatedBox组件时,红色方块会以淡入淡出的方式显示和隐藏。

4、其他方法

<template><div><button @click="showOrHide">显示/隐藏</button><transition name="hello" appear><h1  v-show="isShow">你好啊</h1></transition></div>
</template><script>export default {name: "Test2",data(){return{isShow:true,}},methods:{showOrHide(){this.isShow = !this.isShow;}}}
</script><style scoped>h1{background-color: orange;}.hello-enter-active{animation: a 1s;}.hello-leave-active{animation: a 1s reverse;}@keyframes a {from{transform: translateX(-100px);}to{transform: translateX(0px);}}
</style>
<template><div><button @click="showOrHide">显示/隐藏</button><transition name="hello" appear><h1  v-show="isShow">你好啊</h1></transition></div>
</template><script>export default {name: "Test3",data(){return{isShow:true,}},methods:{showOrHide(){this.isShow = !this.isShow;}}}
</script><style scoped>h1{background-color: orange;transition: 0.5s linear;}/*进入的起点*/.hello-enter{transform: translateX(-100%);}/*进入的终点*/.hello-enter-to{transform: translateX(0);}/*离开的起点*/.hello-leave{transform: translateX(0);}/*离开的终点*/.hello-leave-to{transform: translateX(-100%);}</style>

多个元素过度

<template><div><button @click="showOrHide">显示/隐藏</button><transition-group name="hello" appear><h1  v-show="isShow" key="1">你好啊</h1><h1  v-show="isShow" key="2">你好啊2</h1></transition-group></div>
</template><script>export default {name: "Test4",data(){return{isShow:true,}},methods:{showOrHide(){this.isShow = !this.isShow;}}}
</script><style scoped>h1{background-color: orange;transition: 0.5s linear;}/*进入的起点*/.hello-enter{transform: translateX(-100%);}/*进入的终点*/.hello-enter-to{transform: translateX(0);}/*离开的起点*/.hello-leave{transform: translateX(0);}/*离开的终点*/.hello-leave-to{transform: translateX(-100%);}
</style>

5、引入第三方库(Animate.csss):

地址:https://animate.style/

在这里插入图片描述

引入:

npm install animate.css

导入你的文件

import 'animate.css';

使用:

<template><div><button @click="showOrHide">显示/隐藏</button><transition appear name="animate__animated animate__bounce"  enter-active-class="animate__tada" leave-active-class="animate__backOutUp"><h1  v-show="isShow" key="1">你好啊test5</h1></transition></div>
</template><script>import 'animate.css';export default {name: "Test5",data(){return{isShow:true,}},methods:{showOrHide(){this.isShow = !this.isShow;}}}
</script><style scoped>h1{background-color: orange;}</style>

6、总结
在这里插入图片描述
在这里插入图片描述

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

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

相关文章

【C++】STL优先级队列(priority_queue)

priority_queue 基本介绍 priority_queue就是优先级队列。其头文件就是queue&#xff0c;但是队列和优先级队列关系不大&#xff0c;两个是不同的数据结构。但二者都是适配器&#xff0c;容器适配器。 优先级队列中存放的数据是有优先级的。 其内部有以下成员方法&#xff0c…

使用post-css实现移动端适配

介绍移动端适配以及适配方案 适配原因 移动端不像PC端,有足够大的屏幕展示较多的内容不同的移动端设备&#xff0c;有不同屏幕宽度同样大小的页面元素在不同屏幕宽度设备展示时&#xff0c;布局就会错乱有些元素没有展示在可视范围内有些元素不能撑满整个屏幕&#xf…

【Linux】初始进程地址空间

最近&#xff0c;我发现了一个超级强大的人工智能学习网站。它以通俗易懂的方式呈现复杂的概念&#xff0c;而且内容风趣幽默。我觉得它对大家可能会有所帮助&#xff0c;所以我在此分享。点击这里跳转到网站。 目录 一、再谈fork二、程序地址空间2.1代码验证 三、虚拟地址&am…

成熟的汽车制造供应商协同平台 要具备哪些功能特性?

汽车行业是一个产业链长且“重”的行业&#xff0c;整个业务流程包括了研发、设计、采购、库存、生产、销售、售后等一系列环节&#xff0c;在每一个环节都涉及到很多信息交换的需求。对内要保证研发、采购、营销等业务环节信息流通高效安全&#xff0c;对外要与上、下游合作伙…

Python编程实验一:流程控制结构

目录 一、实验目的与要求 二、实验内容 三、主要程序清单和程序运行结果 第1题 第2题 第3题 第4题 四、实验结果分析与体会 一、实验目的与要求 &#xff08;1&#xff09;通过本次实验&#xff0c;学生应掌握多分支语句 if …elif…else结构的用法&#xff1b; &…

vue3/vue2中自定义指令不可输入小数点.

import { directive } from vueconst noDecimal {mounted(el) {el.addEventListener(keypress, (e) > {if (e.key .) {e.preventDefault() }})} }// 使用自定义指令 directive(no-decimal, noDecimal)使用 标签上添加 v-no-decimal <el-input…

重磅!讯飞星火V3.5正式发布,3大核心能力超GPT-4 Turbo!

1月30日&#xff0c;科大讯飞召开星火认知大模型V3.5升级发布会&#xff0c;这是国内首个基于全国产算力训练的多模态认知大模型。科大讯飞董事长刘庆峰先生、研究院院长刘聪先生出席了大会&#xff0c;并对最新产品进行了多维度解读。 讯飞星火V3.5的7大核心能力实现全面大幅…

P3654 First Step (ファーストステップ)题解

题目 浦之星女子学院的篮球场是一个R行C列的矩阵&#xff0c;其中堆满了各种学校的杂物 (用#表示)&#xff0c;空地 (用.表示) Aqours 现在已经一共有K个队员了&#xff0c;要歌唱舞蹈起来的话&#xff0c;得排成一条1K的直线&#xff0c;一个接一个地站在篮球场的空地上呢 (横…

C++面试:堆排序、归并排序、二分查找等高阶算法

目录 堆排序 (Heap Sort) 步骤&#xff1a; 时间复杂度&#xff1a; 空间复杂度&#xff1a; 归并排序 (Merge Sort) 步骤&#xff1a; 时间复杂度&#xff1a; 空间复杂度&#xff1a; 二分查找 (Binary Search) 步骤&#xff1a; 时间复杂度&#xff1a; 空间复杂…

【Python】P2 Python3 安装使用

目录 新手教程开发教程 本篇博客文章划分为两个主要部分&#xff1a; 【新手教程】旨在为 Python 编程的新手提供指导&#xff0c;适合于初学者入门&#xff0c;但不太适合用于开发大型项目&#xff1b;【开发教程】则面向那些已经有项目开发经验或者希望迅速提升开发技能的读…

BUUCTF-Real-[ThinkPHP]5-Rce

1、ThinkPHP检测工具 https://github.com/anx0ing/thinkphp_scan 漏洞检测 通过漏洞检测&#xff0c;我们发现存在rce漏洞&#xff01; 2、漏洞利用 ---- [!] Name: Thinkphp5 5.0.22/5.1.29 Remote Code Execution VulnerabilityScript: thinkphp5022_5129.pyUrl: http://n…

新春营销不间断,AI 整活更省心

新年、春节历来都是营销的大热节点&#xff0c;各种好物集、年货节、送礼清单比比皆是。这些新鲜玩法的背后是大量的品牌内容「弹药库」。 然而&#xff0c;品牌想在竞争激烈的新春季刷满存在感&#xff0c;并非易事。一方面&#xff0c;节日期间&#xff0c;消费者对于内容的审…

MySQL造数方法

在MySQL中&#xff0c;若要生成大量测试数据&#xff0c;可以使用以下几种方法&#xff1a; 1、手动插入多行数据&#xff1a; INSERT INTO your_table (column1, column2, ...) VALUES (value1_1, value1_2, ...), (value2_1, value2_2, ...), -- 重复此模式以添加更多行 (…

Tensorflow2.0笔记 - where,scatter_nd, meshgrid相关操作

本笔记记录tf.where进行元素位置查找&#xff0c;scatter_nd用于指派元素到tensor的特定位置&#xff0c;meshgrid用作绘图的相关操作。 import tensorflow as tf import numpy as np import matplotlib.pyplot as plttf.__version__#where操作查找元素位置 #输入的tensor是Tr…

【蓝桥杯冲冲冲】动态规划学习 [NOIP2003 提高组] 加分二叉树

【蓝桥杯冲冲冲】动态规划学习 [NOIP2003 提高组] 加分二叉树 蓝桥杯备赛 | 洛谷做题打卡day24 文章目录 蓝桥杯备赛 | 洛谷做题打卡day24[NOIP2003 提高组] 加分二叉树题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示数据规模与约定思路 题解代码我的一些话 [NOI…

Python数据可视化库之holoviews使用详解

概要 数据可视化在各个领域中都起着至关重要的作用&#xff0c;无论是用于数据分析、科学研究、教育还是决策支持。Python作为一门强大的数据科学工具&#xff0c;拥有众多的可视化库。其中&#xff0c;HoloViews是一个备受欢迎的库&#xff0c;它可以轻松创建交互性可视化&am…

PE文件结构 安全分析与恶意软件研究 逆向工程 优化与性能调整 兼容性与移植性分析

了解PE&#xff08;Portable Executable&#xff0c;可移植可执行文件&#xff09;文件结构有多个用途 对于软件开发、安全分析、逆向工程等领域的专业人士来说尤其重要。PE文件格式是Windows操作系统中用于可执行文件、动态链接库&#xff08;DLLs&#xff09;、以及其他文件…

安全防御第五次作业

拓扑图及要求如下&#xff1a; 实验注意点&#xff1a; 先配置双机热备&#xff0c;再来配置安全策略和NAT两台双机热备的防火墙的接口号必须一致双机热备时&#xff0c;请确保vrrp配置的虚拟IP与下面的ip在同一网段如果其中一台防火墙有过配置&#xff0c;最好清空或重启&…

C语言指针学习(1)

前言 指针是C语言中一个重要概念&#xff0c;也是C语言的一个重要特色&#xff0c;正确而灵活地运用指针可以使程序简洁、紧凑、高效。每一个学习和使用C语言的人都应当深入的学习和掌握指针&#xff0c;也可以说不掌握指针就没有掌握C语言的精华。 一、什么是指针 想弄清楚什…

ES证书过期,错误信息: current license is non-compliant for [security]

ES证书过期 一、背景二、解决 一、背景 参考: https://blog.csdn.net/jsugs/article/details/124291689 es日志报错信息&#xff1a;current license is non-compliant for [security] ES的X-pack许可证是提供免费一个月的试用&#xff0c;但是到期之后&#xff0c;就会报这…