Vue | Vue.js 实现过渡动画

news2025/1/9 19:12:45

🖥️ Vue .js专栏:Vue .js 实现过渡动画
🧑‍💼 个人简介:一个不甘平庸的平凡人🍬

✨ 个人主页:CoderHing的个人主页

🍀 格言: ☀️ 路漫漫其修远兮,吾将上下而求索☀️

👉 你的一键三连是我更新的最大动力❤️


目录

一、认识Vue的动画原理

认识动画

Vue的transition动画

Transition组件的原理

二、动画中常见类的作用

过渡动画class

class添加的时机和命名规则

三、animation动画实现

过渡css动画

同时设置过渡和动画(一般不设置) 

四、动画的常见属性设置

显示的指定动画时间

过渡的模式 mode

动态组件的切换

appear初次渲染

五、列表元素动画组实现

认识列表的过渡

列表过渡的基本使用

六、列表元素的移动动画

列表元素的移动动画


一、认识Vue的动画原理

认识动画

在开发中,我们想要给一个组件的 显示和消失添加某种过渡动画,可以很好的增加用户体验

        React框架本身并没有提供任何动画相关的API 所以在React中使用过渡动画需要使用第三方库 react-transition-group

        Vue中为我们提供 一些内置组件和对应的API 来完成动画,利用它们我们可以 方便的实现过渡动画效果

来看看效果:

JavaScript
<template>
  <div class="app">
    <!-- 没有任何动画效果 太深硬了 -->
    <div>
        <button @click="isShow = !isShow">切换</button>
    </div>

    <!-- 点击切换按钮 在显示和隐藏 -->
    <!-- Vue 给的内置组件 -->
    <!-- transition 不是帮你做动画的,是在恰当的时机帮你做恰当的事 -->
    <transition>
      <h2 v-if="isShow">哈哈哈哈</h2>
    </transition>
  </div>
</template>

<script setup>
import { ref } from "vue";

const isShow = ref(false);
</script>

<style scoped>

h2{
    display: inline-block;
}

/* 开始进入为0 */
.v-enter-from,
.v-leave-to {
  opacity: 0;
  transform: scale(0.6);
}

/* 进入后为1 */
.v-enter-to,
/* 从哪里开始离开 */
.v-leave-from {
  opacity: 1;
  transform: scale(1);
}

/* 进入的过程 进行什么操作 */
.v-enter-active,
.v-leave-active {
  transition: all 2s ease;
}
</style>

没有动画的情况下,整个内容的显示和隐藏都会非常的生硬:

        如果我们希望给 单元素或者组件实现过渡动画,可以 使用 transition内置组件 来完成动画

Vue的transition动画

Vue提供了transition的封装组件,在一下情况下,可以给任何元素添加进入/离开 过渡

        条件渲染(使用v-if)条件展示(使用v-show)

        动态组件

        组件根节点

Transition组件的原理

Vue自动给h2元素添加了动画 因为什么呢?

当插入或删除 包含在transition组件中的元素时 Vue将会做以下处理:

        1.自动嗅探 目标元素是否应用了CSS过渡或动画,如果有 那么 在恰当的时机添加/删除 CSS类名

        2 如果 transition 组件提供了 Js钩子函数, 这些钩子函数在恰当的时机被调用

        3 如果 没有找到Js钩子并且也没有检测到CSS过渡/动画 DOM插入 删除操作将会立即执行

二、动画中常见类的作用

过渡动画class

事实上,Vue帮助我们在这些class之间来回切换完成的动画:

V-enter-from: 定义进入过渡的开始状态;

        在元素被插入之前生效,在元素被插入之后的下一帧移除.

V-enter-active: 定义进入过渡生效时的状态.

        在整个过渡的阶段中应用,在元素被插入之前,在过渡/动画完成之后移除.这个类可以被用来定义进入过渡的过程时间,延迟和曲线函数。

V-enter-to: 定义进入过渡的结束状态

        在元素被插入之后下一帧生效(与此同时v-enter-from被移除) 在过渡/动画完成之后移除.

V-leave-from: 定义离开过渡的开始状态.

        在离开过渡被触发时立刻生效,下一帧被移除

v-leave-active:定义离开过渡生效时的状态

        在整个离开过渡的阶段中应用,在离开过渡被触发时立刻生效,在过渡/动画完成之后移除。这个类可以被用来定义离开过渡的过程时间,延迟和曲线函数。

v-leave-to:离开过渡的结束状态

        在离开过渡被触发之后下一帧生效 (与此同时 v-leave-from 被删除),在过渡/动画完成之后移除。

class添加的时机和命名规则

 

class的name命名规则如下:

        如果我们使用的是一个没有name的transition,那么所有的class是以 v- 作为默认前缀;

        如果我们添加了一个name属性,比如 <transtion name="xXiong">,那么所有的class会以 xXiong- 开头

三、animation动画实现

过渡css动画

我们不仅可以用transition来实现动画效果,也可以通过 animation来实现

同时设置过渡和动画(一般不设置) 

Vue为了知道过渡的完成,内部在监听transitionend或animationend 到底使用哪一个取决于元素应用的CSS规则.

        如果我们 只是使用了其中的一个,那么Vue能自动识别类型并设置监听;

如果我们同时使用了过渡和动画呢?

        并且在这个情况下可能某一个动画执行结束时,另外一个动画还没有结束

        在这种情况下,我们可以设置 type 属性为 animation 或者 transition 来明确的告知Vue监听的类型

四、动画的常见属性设置

显示的指定动画时间

        我们可以显示的来 指定过渡的时间 通过 duration属性

duration可以设置两种类型的值:

        number类型:同时设置进入和离开的过渡时间

        object类型:分别设置进入和离开的过渡时间

JavaScript
<transition name="xXiong" type="animation" :duration="1000">
// 单位是 毫秒
// 对象形式
<transition name="xXiong" type="animation" :duration="{enter:800,leave:1000}">

过渡的模式 mode

我们来看看当前的动画在两个元素之间切换的时候存在的问题:

我们会发现 Hello World 和 你好啊李银河 是 同时存在的

        因为 默认情况下 进入和离开动画 是同时发生的

        如果确实我们希望达到这个效果,那么是没问题的;

但如果我们 不希望同时执行进入和离开动画,那么我们需要设置transition的过渡模式

        In-out: 新元素先进行过渡,完成后当前元素过渡离开

        Out-in: 当前元素先进行过渡,完成后新元素过渡进入

动态组件的切换

上面说的同样适用于 动态组件

JavaScript
<transition name="xXiong" mode="out-in">
      <component :is="isShow ? Home : About"></component>
</transition>
// 如果想使用字符串 那么就要用 Options API

appear初次渲染

默认情况下,首次渲染的时候是没有动画的,如果我们希望给他添加上去动画,那么就可以增加另外一个属性appear:

JavaScript
<transition name="xXiong" mode="out-in" appear>
      <component :is="isShow ? Home : About"></component>
</transition>

五、列表元素动画组实现

认识列表的过渡

到现在,过渡动画 我们主要是 针对单个元素或组件

        要么是 单个节点

        要么是 同一时间渲染多个节点中的一个

如果我们希望 渲染的是 一个列表, 并且 该列表中添加删除数据也希望有动画执行 怎么办?

        我们要使用<transition-group>组件 来完成

使用<transition-group> 有如下的特点:

        默认情况下,它不会渲染一个元素的包裹器,但是你可以指定一个元素并以 tag attribute 进行渲染

        过渡模式不可用,因为我们不再相互切换特有的元素

        内部元素总是需要提供唯一的 key attribute 值

        CSS 过渡的类将会应用在内部的元素中,而不是这个组/容器本身

列表过渡的基本使用

JavaScript
<template>
  <div class="app">
    <button @click="addNumber">添加数字</button>
    <button @click="removeNumber">删除数字</button>

    <transition-group tag="div" name="xXiong">
      <!-- 必须要加 key -->
      <template v-for="item in nums" :key="item">
        <span> {{ item }} </span>
      </template>
    </transition-group>
    
  </div>
</template>

<script setup>
import { reactive } from 'vue';

const nums = reactive([0,1,2,3,4,5,6,7,8,9])

const addNumber = () =>{
  nums.splice(randomIndex(),0,nums.length)
}
  
const removeNumber = () =>{
  nums.splice(randomIndex(),1)
}

const randomIndex = () =>{
  return Math.floor(Math.random() * nums.length)
}

</script>

<style scoped>
span {
  margin-right: 10px;
  display: inline-block;
}

.xXiong-enter-from,
.xXiong-leave-to {
  opacity: 0;
  transform: translateY(30px);
}

.xXiong-enter-to,
.xXiong-leave-from {
  opacity: 1;
  transform: translateY(0);
}

.xXiong-enter-active,
.xXiong-leave-active {
  transition: all 2s ease;
}
</style>

六、列表元素的移动动画

列表元素的移动动画

上面的这个案例中, 虽然新增和删除节点都有动画,但是对于那些其他需要移动的节点是没有动画的

可以通过使用一个 新增的v-move的class来完成动画

它会在元素改变位置的过程中应用

像之前的名字一样,可以通过name来自定义前缀

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

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

相关文章

基于51单片机的智能路灯控制系统proteus仿真原理图PCB

功能&#xff1a; 0.本系统采用STC89C52作为单片机 1.LCD1602液晶实时显示当前时间/环境光强/工作模式 2.支持路灯故障检测 3.工作时间内(17~24时)&#xff0c;两个路灯同时点亮&#xff0c;24时以后&#xff0c;B路灯关闭&#xff0c;若检测到由物体通过&#xff0c;路灯B点亮…

R17 redcap

微信同步更新欢迎关注同名modem协议笔记 在5G时代&#xff0c;某些场景的终端并不需要特别复杂&#xff0c;只要满足成本低&#xff0c;功耗小&#xff0c;尺寸小等要求即可&#xff0c;例如视频监控&#xff0c;可穿戴设备&#xff0c;工业无线传感器等&#xff0c;redcap就是…

electron vue 模仿qq登录界面

1、使用vuecli创建vue项目 我用的vue2 vue create qq_test2、安装electron npm install electron -g //or npm install electron12.0.11 //老版本3、vue项目安装Electron-builder打包工具 版本我选择的是12 vue add electron-builder4、在vue项目的src下有个background.…

收藏|多指标时序预测方式及时序特征工程总结

背景 现如今&#xff0c;随着企业业务系统越来越复杂&#xff0c;单指标时间序列预测已不能满足大部分企业需求。在复杂的系统内&#xff0c;如果采用单一的指标进行时间序列预测&#xff0c;由于各个指标相互作用的关系&#xff0c;因此会因为漏掉部分指标因素导致出现预测精…

进程间的通信 - 剪切板

剪切板是系统维护管理的一块内存区域&#xff0c;本机的所有进程都可以访问。当一个进程复制数据时&#xff0c;先将数据放在该内存区&#xff0c;当另一个进程粘贴时&#xff0c;则是从该内存区块取出数据 剪切板操作&#xff1a; 其实在剪切板中也就那几个API在使用&#x…

tf模型落地安卓之旧事重提

之前将tf模型落地安卓了&#xff0c;其实就是clone一下官方的代码&#xff0c;然后配置下环境就打包了&#xff0c;没啥技术含量&#xff0c;现在再看&#xff0c;问题就在环境配置了。 1&#xff0c;Unable to start the daemon process. Q Group 277356808 The project use…

西安某1000M3浮顶油罐设计(成品油库1000m³油罐设计与制造工艺)

目 录 1 浮顶油罐及其发展概况 2 2 设计方案 3 2.1 各种设计方法 3 2.2 各种方法优缺点比较 3 2.3 油罐的基础 4 3 罐壁设计 5 3.1 罐壁的强度计算 5 3.2 浮顶油罐的风力稳定计算 6 3.3 浮顶油罐的抗震计算 9 3.4 罐壁结构 14 4 罐底设计 18 4.1 罐底结构设计 18 4.2 罐底的应…

【离散数学】第三章 测试

1.单选题 A&#xff1d;{1,2,3},A上关系R{<1,2>,<2,2>,<2,3>,<3,3>}&#xff0c;则t(R) A. {<1,2>,<2,2>,<2,3>,<3,3>} B. {<1,2>,<1,3>,<2,2>,<2,3>,<3,3>} C. {<1,1>,<2,2>,<…

【面试宝典】Spring Boot 系列面试题

1、什么是 Spring Boot? 多年来&#xff0c;随着新功能的增加&#xff0c;spring 变得越来越复杂。如果必须启动一个新的 Spring 项目&#xff0c;我们必须添 加构建路径或添加 Maven 依赖关系&#xff0c;配置应用程序服务器&#xff0c;添加 spring 配置。 因此&#xff0c…

Vue(九)——页面路由(1)

目录 路由的简介 路由基本使用 几个注意点 嵌套&#xff08;多级&#xff09;路由 路由的query参数 命名路由 路由的params参数 路由的props配置 路由的简介 理解&#xff1a; 一个路由&#xff08;route&#xff09;就是一组映射关系&#xff08;key - value&#xff…

【毕业设计】深度学习身份证识别系统 - 机器视觉 python

文章目录0 前言1 实现方法1.1 原理1.1.1 字符定位1.1.2 字符识别1.1.3 深度学习算法介绍1.1.4 模型选择2 算法流程3 部分关键代码4 效果展示5 最后0 前言 &#x1f525; Hi&#xff0c;大家好&#xff0c;这里是丹成学长的毕设系列文章&#xff01; &#x1f525; 对毕设有任…

第八章: 项目质量管理

一、规划质量管理 识别项目及其可交付成果的质量要求和标准&#xff0c;并书面描述项目将如何证明符合质量要求和标准的过程。主要作用为整个项目期间如何管理和核实质量提供指南和方向。 输入工具与技术输出 1.项目章程 2.项目管理计划 需求管理计划风险管理计划相关方参与计…

C++ opencv图像直方图

1.图像直方图概念 图像有很多基础概念&#xff0c;在我们学习的过程中因为一些原因无法涉及&#xff0c;但这并不代表它们不重要 今天&#xff0c;我们就来介绍一个概念——图像直方图 图像直方图&#xff0c;是图像处理中很重要的一个基础概念&#xff0c; 有很多的算法&…

用HTML+CSS做一个漂亮简单的旅游网站——旅游网页设计与实现(6页)HTML+CSS+JavaScript

&#x1f468;‍&#x1f393;学生HTML静态网页基础水平制作&#x1f469;‍&#x1f393;&#xff0c;页面排版干净简洁。使用HTMLCSS页面布局设计,web大学生网页设计作业源码&#xff0c;这是一个不错的旅游网页制作&#xff0c;画面精明&#xff0c;排版整洁&#xff0c;内容…

(八)Java算法:堆排序(详细图解)

目录一、前言1.1、概念1.2、大根堆特点二、maven依赖三、流程解析3.1、初始建堆3.2、堆化第一步3.2、堆化第二步3.3、堆化第三步3.4、堆化第四步3.5、堆化第五步3.6、堆化第六步四、编码实现4.1、代码实现4.2、运行结果&#xff1a;扩展一、前言 1.1、概念 根据堆的结构可以分…

彩印图文版《Elasticsearch实战》文档,阿里内部共享,堪称精品

学习是一种基础性的能力。然而&#xff0c;“吾生也有涯&#xff0c;而知也无涯。”&#xff0c;如果学习不注意方法&#xff0c;则会“以有涯随无涯&#xff0c;殆矣”。 学习就像吃饭睡觉一样&#xff0c;是人的一种本能&#xff0c;人人都有学习的能力。我们在刚出生的时候…

Lesson1强化学习(RL)初印象 学习笔记

一、强化学习引入 ​ 人的智能可以遗传获得也可以通过后天学习&#xff1b;学习有两种&#xff0c;模仿前人的经验是一种学习&#xff1b;如果没有前人的经验可以学习&#xff0c;就需要和环境进行交互&#xff0c;得到反馈来学习。 #mermaid-svg-XUxguPj6VHcJMK3W {font-famil…

the account is locked

感谢阅读问题描述解决方案1.WinR打开命令行输入&#xff1a;sqlplus &#xff0c;或者使用sqlplus / as sysdba;无需输入密码。2.假设我们要解锁的账户是scott3.修改密码&#xff0c;从而避免再次被锁4.重启服务或者客户端&#xff08;看你是桌面版还是服务器版&#xff09;&am…

警惕,3D建模为什么选3dsMAX不选MAYA

如今现在的游戏建模都是次世代建模&#xff0c;3DMAX确实是主流软件之一&#xff0c;但是为什么说MAYA更好呢❓ 首先&#xff0c;两款软件都很适合用现代的建模&#xff0c;但是难度上有一定的差异❌ • 软件区别 &#x1f340;3DSMAX&#xff1a; 它是目前使用最广泛的3d软…

十、Mysql的DQL语句

Mysql的DQL语句十、Mysql的DQL语句select的查询一、查看系统参数二、select常用函数三、select的单表查询1、from子句2、where子句2.1 where配合等值查询2.2where配合比较操作符(> < > < <>)2.3where配合逻辑运算符(and or )2.4where配合模糊查询2.5where配合…