CSS 之 transition过渡动画

一、简介

​ CSS 制作 Web 动画有两种方式: 帧动画(Keyframe Animation)和过渡动画(Transition Animation)。针对不同的业务场景中,我们应该选择不同的动画方式,通常来说:对于交互元素,会使用过渡动画,而对于连续的装饰性元素,则应该使用帧动画。

​ 本文章将会仔细讲解transition过渡动画的相关知识,让你对其有一个全面的了解。

二、过渡动画

1、基本概念

​ 默认情况之下,修改CSS中的样式属性,其样式的变化是瞬间发生的,这显然是十分生硬,不够自然的,用户体验不够友好。

<style>.btn {width: 100px;height: 40px;background: green;}.btn:hover {background: yellow;transform: translateY(10px);}
</style><div class=btn>按钮</div>

​ 为了让样式变化更加平滑自然,可以使用CSS 的过渡(transition)特性,可以在元素的 A 状态(初始状态)和元素的 B 状态(目标状态)之间进行插值计算。这个插值计算是由浏览器自动完成的,它会根据元素的初始状态 A 和结束状态 B 之间创建“中间”状态。从而使元素从一种状态(A )平滑过渡到另一种状态(B)。

.btn {width: 100px;height: 20px;background: green;/* 增加过渡属性 */transition: all 250ms linear;
}
页面效果对比:

在这里插入图片描述

2、过渡属性
① transition

​ 该属性用来设置元素的过渡动画,是过渡属性的简写形式,属性值可以包含四部分transition-propertytransition-durationransition-timing-functiontransition-delay

​ 可以同时针对多条CSS属性设置多个属性值,属性值之间通过,连接。

/* 设置一条属性的过渡动画 */
transition: transform 200ms ease;
/* 同时设置多条属性的过渡动画 */
transition: transform 200ms ease, color 200ms ease;
/* 全属性简写 */
transition: transform 400ms linear 0.5s allow-discrete;
② transition-property

​ 该属性用于指定要实现过渡动画的CSS属性,通常为transition中的第一个属性值,也可单独设置该属性。属性值可以为一个具体的CSS属性,如:marginbackground-color等等;也可以为一个关键词all,表示当前元素所有变化的属性都实现过渡。

/* 指定单条实现过渡动画的属性 */
transition-property: transform;
/* 指定多条实现过渡动画的属性 */
transition-property: transform, color;
③ transition-duration

​ 该属性用于指定完成过渡动画所需的时间,通常为transition中的第二个属性值,也可单独设置该属性。属性值为时间+单位,单位为秒s或毫秒ms,针对不同的过渡可以设置不同的时间。

/* 指定所有过渡动画的时间 */
transition-duration: 0.2s;
/* 指定多个过渡动画的时间 按顺序与 transition-property 中的属性对应 */
transition-duration: 0.2s, 200ms;
④ ransition-timing-function

​ 属性用于指定过渡动画执行的速度曲线,通常为transition中的第三个属性值,也可单独设置该属性。常见属性值有:linearease(默认值)、ease-inease-outease-in-out 。其次还有:steps()cubic-bezier()(贝塞尔曲线函数)。

/* 指定所有过渡动画的速度曲线 */
transition-timing-function: ease-in-out;
/* 指定多个过渡动画的速度曲线 */
transition-timing-function: ease, steps(4);

属性值详解:

  • linear表示匀速运动,速度曲线是一条直线。

  • ease(默认值)表示慢-快-慢,初期速度很慢,然后先逐渐加速,再快速减速,最终缓慢结束。加速过程较缓,减速过程较快。

  • ease-out表示减速运动,先快后慢,初期速度很快,然后逐渐减速,最终缓慢结束。

  • ease-in表示加速运动,先慢后快,初期速度很慢,然后逐渐加速,最终快速结束。

  • ease-in-out表示慢-快-慢,初期速度慢,然后逐渐加速,中期速度最快,然后逐渐减速,最终缓慢结束。加速过程和减速过程相当。

  • linear() 函数定义了一个分段线性函数,可以在其各个点之间线性插值,从而允许你模拟出更复杂的动画效果,比如弹跳和弹簧等效果。JS或SVG可以通过linear曲线生成器 生成相应的曲线参数。

  • steps()函数定义了分步运动,其效果相当于逐步执行过渡动画,类似于帧动画,接受两个参数,第一个参数指定的是步数,第二个参数指定的是方向。第二个参数值可以是 jump-startjump-endjump-nonejump-bothstartend(默认值) ,其中 startjump-start 表现行为一样,同样的 endjump-end 表现行为一样。函数还有两个预定义的关键字:step-startstep-end。前者等同于 steps(1, start),而后者等同于 steps(1, end)

    jump-start表示第一步动画在开始时发生;jump-end 表示最后一步动画在结束时发生;jump-both 表示在 0% 和 100% 处均出现跳跃,相当于在动画过程中加上一步;表示两端均无跳跃,而是在 0% 处和 100% 处将值各保持 1/n 的时长。更多内容可以查看:easing-function

  • cubic-bezier()用于定义贝塞尔曲线,贝塞尔曲线由 P0、P1、P2 和 P3 四个点进行定义。P0 和 P3 是曲线的起点和终点,在 CSS 中,这两个点是固定的,因为坐标是成比例。P0 为 (0, 0),代表初始时间和初始状态,P3 为 (1, 1),代表最终时间和最终状态。其余的中间点 P1(x1,y1)、P2(x2,y2) 是可以动态改变的两个点,对应 cubic-bezier(x1,y1,x2,y2) 中的四个参数,通过改变 P1、P2 两点的坐标值来动态生成的贝塞尔曲线表示动画中的速度变化。

    ​ 具体的贝塞尔曲线很难直接书写出来,我们可以通过贝塞尔曲线生成器,来获取对应的曲线值。

    ​ 在固定y的情况下,x越大运动越慢,在固定x情况下,y越大运动越快。y如果是负数,则元素会变小,y’如果大于1,则会变大,但最终还会恢复为1。

    在这里插入图片描述

⑤ transition-delay

​ 该属性用于设置在过渡动画被触发之后,在开始之执行前需要等待的时间,通常为transition中的第四个属性值,默认值为0,单位为秒s或毫秒ms。属性值为正数时,会等待这段时间后再执行过渡动画;属性值为0或者负数时,则会立即执行过渡动画。该属性也可以作为一条单独的属性进行设置。

​ 如果transition中分开设置了多条属性的过渡,则transition-delay也可以设置多个等待时间,会按照先后顺序一一与过渡动画对应。

/* 设置两条属性进行过渡 */
transition: transform 200ms ease, color 200ms ease;
/* 分别设置两条属性的延迟等待时间 */
transition-delay: 0.2s, 400ms;
⑥ transition-behavior(兼容性一般)

​ 该属性用于设置离散属性的平滑过渡效果,属性值为normal(默认)allow-discrete(开启离散属性过渡),该属性可以作为transition中的第五个属性值。但该属性兼容性不是很好,因此并不常用。

在这里插入图片描述

​ 像display等不连续、无中间状态的属性,被称为离散属性。本来这些属性都是无法设置过渡动画的,但在设置transition-behavior: allow-discrete;,且同时与普通的连续属性一起实现过渡动画时,则会启动离散属性的过渡效果。但单独为离散属性实现过渡动画时,该属性不会起作用。

​ 通常会将离散属性和连续属性的transition-duration设置相同的值,其呈现的效果为:连续属性动画执行结束后,立即变更离散属性的状态。例如:结合opacitydisplay实现元素逐渐位移消失的效果:

<style>.btn2 {width: 100px;height: 40px;background: green;margin-top: 30px;opacity: 1;display: block;transition: opacity 500ms linear, display 500ms linear;/* 开启离散属性的过渡 */transition-behavior: allow-discrete;}.btn2-click {opacity: 0;display: none;}
</style><div class="btn2">按钮2</div>
<script>const btn2 = document.querySelector('.btn2');btn2.addEventListener('click', () => {btn2.classList.toggle('btn2-click');})
</script>
3、可设置过渡的CSS属性

​ 一般来说,只有在其起始状态和最终状态之间具有“中间状态”的属性才能设置过渡动画,也可以称这些属性为连续属性。例如:

  • 变换属性:transform
  • 颜色属性:colorborder-colorbackground-color等。
  • 阴影属性:box-shaowtext-shadow等。
  • 长度和尺寸属性:whidthheight等。
  • 位置属性:topleftmarginpadding等。
  • 透明度属性:opacity
  • 显示/隐藏属性:visibility
  • 背景属性:background-sizebackground-position
  • 滤镜属性:filter
  • 混合模式属性:mix-blend-modebackground-blend-mode
  • 剪切和蒙版属性:clip-pathmask-size等。
4、过渡动画的触发器

​ 过渡动画关键点就是必须包含两个状态—开始状态和结束状态,而且在这两个状态中同一属性在样式上发生了变化。触发两种状态转换的节点,被称为触发器。

常见的触发器有:
  • 悬停触发:鼠标悬停在元素上时触发过渡动画,通常使用:hover伪类选择器实现。

  • 焦点触发:元素失去焦点时触发过渡动画,通常使用:focus:focus-within:focus-visible 等伪类选择器实现。

  • 锚点链接触发:锚链接元素被点击时触发过渡,通常使用:target伪类选择器实现。

  • 激活状态触发:元素被点击并按住时触发过渡,通常使用:active伪类选择器实现。

  • 表单状态触发:表单元素被选择时触发过渡(输入框、单选框等),通常使用:checked:valid:invalid:required等表单状态伪类选择器。

  • class类名变更触发:元素的class发生变化时,如果包含可过渡的属性,则会触发过渡。

5、触发和退出使用不同过渡效果

​ 在过渡动画中,我们可以为进入和退出设置不同的的过渡效果,从而实现更加复杂的动画交互。

​ 例如:可以使用:hover作为触发器,实现进入和退出的不同过渡动画效果。

<style>.btn {width: 100px;height: 40px;/* 元素本身的过渡 默认在进入和退出时 都生效 */transition: transform 200ms ease;}.btn:hover {transform: translateY(10px);/* 进入时的过渡 仅生效于进入动画 优先级高于元素本身的过渡 会进行覆盖 */transition: transform 400ms linear;}
</style>
</head><div class="btn">按钮</div
6、过渡相关事件
① transitionrun

​ 该事件在过渡动画被触发后立即触发,即使过渡动画设置了transition-delay属性,也不会影响该事件的执行。

​ 如果过渡动画中涉及多个CSS属性的变更,则会一一触发多个该事件。

element.addEventListener("transitionrun", (event) => {});
② transitionstart

​ 该事件在过渡动画实际开始执行时触发,如果过渡动画设置了transition-delay属性,则该事件会在等待时间结束后再触发。如果未设置等待时间,则仍会在transitionrun事件后触发。

​ 如果过渡动画中涉及多个CSS属性的变更,则会一一触发多个该事件。

element.addEventListener("transitionstart", (event) => {});
③ transitionend

​ 该事件在过渡动画执行结束后触发,如果在当前过渡动画结束之前,对应的过渡动画被取消,则该事件不会被触发。

​ 如果过渡动画中涉及多个CSS属性的变更,则会一一触发多个该事件。

element.addEventListener("transitionend", (event) => {});
④ transitioncancel

​ 该事件在过渡动画开始执行但又被取消后触发,过渡动画被取消的情况包含三种:transition-property属性被修改、display属性被设为none和触发器停止触发(例如:鼠标移出hover动画元素)。

​ 如果过渡动画中涉及多个CSS属性的变更,则会一一触发多个该事件。

element.addEventListener("transitioncancel", (event) => {});
7、过渡事件对象:

​ 所有过渡事件的事件对象event除了继承Event的相关属性之外,还拥有三个特殊属性:

  • event.propertyName(只读):表示当前过渡的CSS属性的名称字符串。
  • event.elapsedTime(只读):表示触发此事件时,过渡动画已经运行的时间,单位为秒(s)。
  • event.pseudoElement(只读):表示当前过渡动画的绑定元素是否为伪元素,如果是伪元素则值为::伪元素名称,如果绑定的不是伪元素,则值为""
案例代码:
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>过渡动画</title><style>.btn {width: 100px;height: 40px;background: green;/* 元素本身的过渡 在进入和退出且无其他过渡时 都生效 */transition: all 800ms ease;}.btn:hover {background: yellow;transform: translateY(10px);/* 进入时的过渡 优先级高于元素本身的过渡 */transition: all 400ms linear 2s allow-discrete;}
</head><body><div class="btn">按钮</div><script>const btn = document.querySelector('.btn');btn.addEventListener('transitionrun', (event) => {console.log('transitionrun---', event);})btn.addEventListener('transitionstart', (event) => {console.log('transitionstart---', event);})btn.addEventListener('transitionend', (event) => {console.log('transitionend---', event);})btn.addEventListener('transitioncancel', (event) => {console.log('transitioncancel---', event);})</script>
</body></html>
控制台输出:

在这里插入图片描述

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

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

相关文章

vue3插槽的name和v-slot的研究

slot可以分为具名插槽和默认,默认插槽name是default 在父组件的template需要些v-slot/#,没写不生效,而在父组件下,而没被template包含的默认放在template且含有#default. 1)没写slot,可以不写template,也可写default的template2)写了name的slot,即使是default也必须些template…

STM32G431RBT6之LCD与LED配置

首先,配置时钟树,时钟树的配置在我的另外一篇博客里,这里不再赘述. LCD与LED具有共同的IO口,同时创建工程较好. 打开原理图,发现LED的IO口是PC8~PC15,还有一个容易看漏的PD2.LCD的IO口是PC0到PC15. 当然,看产品手册也可以知道,但是还是推荐大家看原理图. 打开cubumx,给PC0~PC…

Java设计模式 _结构型模式_过滤器模式

一、过滤器模式 1、过滤器模式 过滤器模式&#xff08;Filter Pattern&#xff09;是这一种结构型设计模式。过滤器&#xff0c;顾名思义&#xff0c;就是对一组数据进行过滤&#xff0c;从而最终获取到我们预期的数据。 2、实现思路 &#xff08;1&#xff09;、定义过滤器的…

想要应聘前端工程师——学习路线指南

前端工程师学习路线 按照前端岗位需求,以优先学习工作更需要,面试更常考的内容为原则,由浅入深,层层铺垫,与时俱进,可以较容易地总结出前端学习路线图: HTML / CSS / JavaScript 基础学习 《Web 入门》 MDN 权威入门指南,HTML / CSS / JavaScript 快速上手 《CSS 世界…

华为OD机试 - 密码解密(Java 2024 C卷 100分)

华为OD机试 2024C卷题库疯狂收录中&#xff0c;刷题点这里 专栏导读 本专栏收录于《华为OD机试&#xff08;JAVA&#xff09;真题&#xff08;A卷B卷C卷&#xff09;》。 刷的越多&#xff0c;抽中的概率越大&#xff0c;每一题都有详细的答题思路、详细的代码注释、样例测试…

ChatGPT/GPT4 科研实战教程-包括论文写作、数据分析、科研绘图、PPT制作,程序开发

从2022年3月&#xff0c;OpenAI公司发布chatGPT3.5开始&#xff0c;以ChatGPT为代表的人工智能内容生成技术&#xff08;简称AIGC&#xff09;引起了广泛关注&#xff0c;我们进入了全民AI时代。 因此&#xff0c;我们需要了解和掌握AI思维&#xff0c;才能更好适应这个时代的…

uniapp微信小程序-分享

https://developers.weixin.qq.com/miniprogram/dev/component/button.html https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/share.html#%E4%BD%BF%E7%94%A8%E6%8C%87%E5%BC%95 参考未整理 自定义参考未整理

使用Canal实现MySQL主从同步

说明&#xff1a;本文介绍如何使用Canal实现MySQL主从同步的效果&#xff0c;关于Canal入门使用参考&#xff1a;Canal入门使用 启动Canal 首先&#xff0c;设置Canal服务器里&#xff0c;目标节点&#xff08;即监测的MySQL节点&#xff09;的配置&#xff0c;启动Canal服务…

Scala 03 —— Scala OOP Extension

Scala 2.1 —— Scala OOP Extension 一、正则 文章目录 Scala 2.1 —— Scala OOP Extension一、正则1.1 Java正则和Scala正则的区别1.2 Java正则和Scala正则的的基本知识点Java正则Scala正则 1.3 练习练习一&#xff1a;使用正则表达式解析日志方法一&#xff1a;使用findAl…

心理学上有个概念叫:习惯性反驳(附上解决办法)

在心理学上&#xff0c;有一个词&#xff0c;叫做习惯性反驳。 什么意思呢&#xff1f; 就是不管你说什么&#xff0c;他都要反驳你&#xff0c;最后把你带入负面的情绪黑洞&#xff0c;搞得你非常崩溃。 一个总是习惯性反驳的人&#xff0c;其实是非常可怕的。 习惯性反驳的3个…

与Apollo共创生态:Apollo7周年大会自动驾驶生态利剑出鞘

前言 4月22日&#xff0c;百度Apollo在北京车展前夕举办了以“破晓•拥抱智变时刻”为主题的智能汽车产品发布会&#xff0c;围绕汽车智能化&#xff0c;发布了智驾、智舱、智图等全新升级的“驾舱图”系列产品。 1、7周年大会 自2013年百度开始布局自动驾驶&#xff0c;201…

PotatoPie 4.0 实验教程(24) —— FPGA实现摄像头图像中心差分变换

为什么要对图像进行中心差分变换&#xff1f; 对图像进行中心差分变换的主要目的是计算图像中每个像素点的梯度。梯度在图像处理中是一个非常重要的概念&#xff0c;它可以用来描述图像中灰度变化的快慢和方向&#xff0c;常用于边缘检测、特征提取和图像增强等任务中。 具体…

windows服务启动提示‘服务没有响应控制功能’(mysql启动报错)

在安装mysql的时候&#xff0c;在windows服务项启动 或 使用命令net start mysql 时启动是报错&#xff0c;提示 服务没有响应控制功能 发生原因&#xff1a; Windows10 x64 或 更高的操作系统&#xff0c;有些系统缺少一些组件 解决办法&#xff1a; 1、下载最新的 Microsoft …

clickhouse安装部署

虚拟机&#xff1a;virtualbox7.0 操作系统&#xff1a;ubuntu server 22.04.3 虚拟机硬件&#xff1a;cpu 1&#xff0c;内存 2G&#xff0c; 硬盘 100G 采用默认安装 参照 https://clickhouse.com/docs/en/install#quick-install 安装部署 对于Debian、Ubuntu&#xff0c…

版本比对sql

弹窗 index <template><el-dialogtitle"版本":visible.sync"dialogVisible"width"55%"center:close-on-click-modal"false":close-on-press-escape"false":before-close"beforeClose"open"open&q…

【Linux网络】DHCP原理与配置

目录 一、DHCP工作原理 1.了解DHCP服务 2.使用DHCP的好处 3.DHCP的分配方式 二、DHCP的租约过程 三、DHCP场景应用实验 一、DHCP工作原理 1.了解DHCP服务 DHCP&#xff08;Dynamic Host Configuration Protocol&#xff0c;动态主机配置协议&#xff09; 由Internet工作…

【MyBatis】使用MyBatis框架在两张表是一对多的情况下,进行分步查询,发现对查询出来的结果进行封装时没有将实体类的id进行赋值

Catalog MyBatis在两张表是一对多的情况下,进行分步查询&#xff0c;发现对查询出来的结果进行封装时没有将实体类的id进行赋值1. 表结构2. 场景3. 实现方式具体步骤 4 .测试5. 解决方法 MyBatis在两张表是一对多的情况下,进行分步查询&#xff0c;发现对查询出来的结果进行封装…

企业工厂如何逆风翻盘:VR全景打破多重桎梏

现阶段&#xff0c;制造业工厂面临的困境&#xff0c;就是用着上百万的设备&#xff0c;却赚着几毛钱的利润。传统的工厂参观方式也存在着很多的局限性&#xff0c;例如时间上不方便、不能实地参访、生产线具有隐患等&#xff0c;都会使得参观者不能深入地了解工厂的生产环境和…

Python初级笔记6 函数

函数概念 函数是一段具有特定功能的代码的集合。函数的目的主要在于降低编程难度与增加代码复用。一组语句等价于一个函数&#xff0c;&#xff0c;需要使用这组语句的地方直接调用函数名即可。函数的定义也叫函数的声明&#xff0c;定义后的函数不能直接运行需要通过调用 函数…

《苍穹外卖》Day12部分知识点记录——数据统计-Excel报表

一、工作台 需求分析和设计 接口设计 今日数据接口订单管理接口菜品总览接口套餐总览接口订单搜索&#xff08;已完成&#xff09;各个状态的订单数量统计&#xff08;已完成&#xff09; 代码实现 今日数据接口 1. WorkspaceController 注意不要导错包了 package com.sk…