深入探索CSS动画的魅力-附带动画实例

news2025/1/5 10:03:13

一、网页动画发展简史

GIF动画

GIF全称为“Graphics Interchange Format”,是一种基于LZW算法的连续色调无损压缩格式。
由于其文件小、无损压缩、易于播放等优点,GIF成为了网页动画的最初选择。然而,GIF动画的色彩数量和帧数有限,而且不能包含声音,因此其表现力相对有限。

R-C-1.gif

Flash动画

Flash动画是一种使用Macromedia公司开发的Flash软件创建的动画。它具有以下特点:

  • 基于矢量图形:Flash动画使用矢量图形,这意味着图形可以被任意缩放而不会降低图像质量。
  • 插件工作方式:Flash以插件方式工作,用户可以在浏览器上安装Flash插件,快速启动和观看Flash动画。
  • 流式播放技术:Flash动画采用流式播放技术,使得动画可以边下载边播放,大大减少了用户等待的时间。
  • 交互式设计:Flash动画不仅具有丰富的视觉效果,还提供了交互性,使得用户可以与动画进行互动。
  • 跨平台性:Flash动画可以在多种操作系统和浏览器上播放,这使得它成为一种非常流行的网络动画格式。
  • 强大的功能:Flash软件提供了绘图、编辑图形、补间动画和遮罩等基本功能,使得用户可以创建出各种效果的动画。

然而,随着移动设备的普及和HTML5技术的兴起,Flash逐渐被淘汰。

JavaScript动画

随着JavaScript库如jQuery的出现,开发者开始使用JavaScript来创建更丰富的交互式动画。这些库简化了DOM操作和动画效果的实现。

HTML5/CSS3

HTML5引入了<canvas><svg>元素,提供了原生绘图功能。CSS3开始,引入了更多的动画和过渡效果。
通过使用CSS3的动画关键帧(@keyframes)、过渡(transition)等特性,可以轻松地创建各种复杂的动画效果。
同时,CSS3动画也具有更好的兼容性和性能。

WebGL

WebGL是一种基于OpenGL ES 2.0的图形渲染协议,可以在不需要任何插件的情况下在浏览器中进行3D图形渲染。通过WebGL,开发者可以创建更复杂的3D动画和交互式体验。

React和Vue动画

随着前端框架的发展,例如React和Vue,也提供了专门的动画库(如React Spring、Vue.js的过渡效果),简化了在组件级别实现动画的过程。

Web动画API

Web动画API是一组用于控制动画序列的JavaScript接口。例如AnimationAnimationTimeline等;它允许开发者使用JavaScript直接控制CSS动画和SVG动画。

二、原生CSS动画

动画属性(animation)

动画属性用于决定动画的播放时长、播放次数以及播放速度等。

基本语法
animation: duration | easing-function | delay | iteration-count 
           | direction | fill-mode | play-state | name
// 实例:
animation: 3s ease-in 1s infinite reverse both running animateName;

CSS animation 属性是一个简写属性,用于设置六个动画属性:

  • animation-name: 定义动画的名称,与@keyframes规则中的名称相对应。
  • animation-duration: 定义动画完成一个周期所需要的时间,以秒或毫秒计。默认值为0(动画是否可见取决于animation-fill-mode 的值)。
  • animation-timing-function: 定义动画的速度曲线。默认值为"ease"。
  • animation-delay: 定义动画在何时开始。动画开始前的延迟时间,以秒或毫秒计。默认值为0(动画会立即开始)。
  • animation-iteration-count: 定义动画应该播放的次数。默认值为1(动画将从开始播放到结束只播放一次)。
  • animation-direction: 定义动画应正向播放、反向播放还是在正向和反向之间交替播放。。默认值为“normal”(动画应该正向播放)。
  • animation-fill-mode:定义动画在执行之前和之后如何将样式应用于其目标。默认值为“none”(当动画未执行时,动画将不会将任何样式应用于目标)。
  • animation-play-state:定义动画是运行还是暂停。默认值为“running”(当前动画正在运行)。
实例

旋转元素

16-4.gif

动态更改元素大小及透明度

16-3.gif

可访问代码地址查看源码实现

关键帧(@keyframes)

关键帧用于定义动画在不同阶段的状态,可以通过百分比或关键词(例如“from”和“to”)来定义动画的起始和结束状态。

基本语法

使用from(0%) 和to(100%),指定动画的开始或结束状态。

@keyframes animation-name {  
  from {
    transform: translateX(0%);
  }
  to {
    transform: translateX(100%);
  }
}

使用百分比,指定动画在不同阶段需要触发的样式。

@keyframes animation-name {  
  0% {
    top: 0;
    left: 0;
  }
  30% {
    top: 50px;
  }
  68%,
  72% {
    left: 50px;
  }
  100% {
    top: 100px;
    left: 100%;
  }
}
实例

使用from,to定义单词“Hello”从左向右移动;使用百分比使单词"World"从右向左移动。

animate-succces1.gif

变换(Transform)

CSS transform 属性允许旋转,缩放,倾斜或平移给定元素。这是通过修改 CSS 视觉格式化模型的坐标空间来实现的。

基本语法
transform: none | transform-function | initial | inherit;
  • none表示没有任何转换效果。
  • transform-functions表示一个或多个转换函数,如translate(), rotate(), scale()等。
  • initial表示将属性设置为初始值。
  • inherit表示从父元素继承该属性。
transform-function

<transform-function>属性用于对元素进行转换操作,它提供了多种转换方式,包括旋转(rotate)、缩放(scale)、移动(translate)、倾斜(skew)和矩阵变换(matrix)等。这些转换操作可以单独使用,也可以组合在一起使用,以实现更复杂的变换效果。

旋转(rotate)

使用rotate()函数是一种将元素围绕一个定点旋转而不变形的转换。旋转角度可以是正值(顺时针旋转)或负值(逆时针旋转)。其中,转换定点由transform-origin属性指定,默认值是 center

// 将元素顺时针旋转45度
transform: rotate(45deg);
缩放(scale)

使用scale()函数可以按指定的倍率缩放元素。当只有一个参数时,表示水平和垂直方向同时缩放该倍率;当有两个参数时,第一个参数指定水平方向的缩放倍率,第二个参数指定垂直方向的缩放倍率。

// 将元素水平方向和垂直方向同时缩小到原来的一半
transform: scale(0.5);
移动(translate)

二维平移: 使用translate()函数可以将元素在X轴和Y轴方向上平移指定的距离。可以使用translateX()函数仅在X轴方向上平移元素,使用translateY()函数仅在Y轴方向上平移元素。

三维平移:如果设置三个长度值或百分比,表示分别指定 X 轴、Y 轴、Z 轴的值进行三维平移。等同于translate3d() 函数(3D 平移)。

// 将元素在X轴方向上平移100像素,在Y轴方向上平移50像素。
transform: translate(100px, 50px);
// 将元素在X轴方向上平移100像素,在Y轴方向上平移50像素,在Z轴方向上平移20像素。
transform: translate(100px, 50px, 20px);

translate 也支持独立于 transform 属性,单独声明平移变换。

translate: 50% 105px 5rem;
倾斜(skew)

使用skew()函数可以将元素在水平方向和垂直方向上倾斜指定的角度。当只有一个参数时,表示水平方向的倾斜角度;当有两个参数时,第一个参数表示水平方向的倾斜角度,第二个参数表示垂直方向的倾斜角度。

// 将元素在水平方向上倾斜30度
transform: skew(30deg);
矩阵变换(matrix)

CSS的matrix属性是用于实现2D变换效果的函数,它基于数学中的矩阵概念。通过矩阵的乘法运算,可以将多个变换效果组合在一起,实现复杂的变换效果。

语法

matrix(a, b, c, d, tx, ty);
matrix( scaleX(), skewY(), skewX(), scaleY(), translateX(), translateY() )

其中,ad控制元素在水平方向和垂直方向上的缩放,bc控制元素在水平和垂直方向上的倾斜,txty控制元素在水平和垂直方向上的平移。

矩阵的六个参数对应于一个2x3的矩阵。这六个参数给定特定的值,可以实现特殊的变换效果。

实现平移效果,修改参数txty

实现缩放效果,修改参数ad

实现旋转效果,修改参数a, b, c, 和 d

例如,要实现一个元素的平移效果,可以将矩阵设置为:

    transform: matrix(1, 0, 0, 1, 100px, 50px);

这个例子将元素在X轴方向上平移100像素,在Y轴方向上平移50像素。

需要注意的是,CSS中的矩阵变换是基于2D变换的,不包含3D变换效果。对于更复杂的3D变换效果,可能需要使用其他的转换函数,如rotateX、rotateY、rotateZ等。

实例

旋转+缩放动画

16-8.gif

多种组合变换

16-9.gif

在这个示例中:

  • translate(x, y) 用于在X轴和Y轴上移动对象。
  • rotate(angle) 用于按指定角度旋转对象。
  • scale(x, y) 用于在X轴和Y轴上缩放对象。
  • skew(x-angle, y-angle) 用于在X轴和Y轴上倾斜对象。
  • matrix(a, b, c, d, e, f) 是一个综合性的函数,允许组合多个变换。

可访问代码地址查看源码实现

过渡(Transition)

CSS 过渡可以决定哪些属性发生动画效果(通过明确地列出这些属性),何时开始(通过设置延时),持续多久(通过设置时长)以及如何动画(通过定义缓动函数,比如线性或先快后慢)。

基本语法
transition: property | duration 
            | timing-function | delay;

transition属性是一个简写属性,用于设置四个过渡相关的子属性:

  • property:指定应用过渡效果的CSS属性名称,例如width、height、background-color等。可以使用all来指定所有可动画的属性都将应用过渡效果。
  • duration:定义过渡效果的持续时间,通常以秒(s)或毫秒(ms)为单位。例如,2s或2000ms表示过渡效果将在2秒内完成。
  • timing-function:定义过渡效果的速度曲线。常见的值包括linear(匀速)、ease(慢到快再到慢)、ease-in(慢到快)、ease-out(快到慢)
  • ease-in-out(慢到快再到慢)等,或者可以使用cubic-bezier()函数来自定义速度曲线。
  • delay:定义过渡效果开始前的延迟时间,也以秒或毫秒为单位。例如,1s或1000ms表示过渡效果将在1秒后开始。

这些子属性也可以单独设置:

transition-property: width;  
transition-duration: 2s;  
transition-timing-function: ease-in-out;  
transition-delay: 1s;
实例

鼠标悬浮,修改卡片的缩放、背景颜色和阴影

16-13.gif

可访问代码地址查看源码实现

三、CSS动画性能及优化

性能瓶颈

CSS原生动画的性能瓶颈主要来自于两个方面:计算复杂度和渲染性能。

计算复杂度

计算复杂度指浏览器在处理动画效果时所需的计算量。这主要涉及到样式的计算、布局(Layout)和绘制(Paint)操作。如果动画涉及复杂的样式计算或引发频繁的布局和绘制,可能会导致性能瓶颈。以下是一些具体的例子:

// 复杂样式计算
.element { 
    width: calc(50% + 100px); 
    height: calc(30vh - 20px); 
    background-color: hsl(120, 70%, 80%);
}

// 在动画中频繁获取布局属性
const elementWidth = element.offsetWidth;

// 复杂的选择器可能需要更多的计算资源来匹配元素
.container > div:not(:last-child):hover {
  transform: scale(1.2);
}
渲染性能

渲染性能涉及浏览器如何绘制动画帧以及如何在屏幕上显示它们。这包括合成图层的创建、纹理的合成和屏幕的刷新。过于复杂或频繁的渲染操作可能导致动画不流畅,尤其是在性能较低的设备上。

// 鼠标悬停时会导致频繁的重绘和回流
.element {
  left: 10px;
  top: 10px;
  transition: left 1s, top 1s;
}

.element:hover {
  left: 100px;
  top: 100px;
}

// 在某些情况下,为多个元素应用硬件加速可能会导致更多的复合层,增加渲染工作量。
.element1, .element2, .element3 {
  transform: translateZ(0);
}

// 过于频繁的透明度变化可能导致浏览器强制进行重绘
.element {
  transition: opacity 0.5s;
}
.element:hover {
  opacity: 0.5;
}

此外,还有一些其他因素也会影响CSS原生动画的性能,例如浏览器对CSS动画的支持程度、硬件性能等。例如,一些老旧的浏览器可能不支持某些CSS动画特性,或者在某些设备上,GPU性能不足也会影响动画的性能。

优化方法

使用硬件加速

通过开启硬件加速,将计算密集型的任务交给GPU处理,可以大大提高动画的性能。
在CSS中,可以使用transform属性或opacity等属性来开启硬件加速。

在个别复杂的计算场景下,也可以使用will-change属性。该属性提供了一种告知浏览器该元素会有哪些变化的方法,这样浏览器可以在元素属性真正发生变化之前提前做好对应的优化准备工作。具体需要结合业务场景综合考量并使用。

使用requestAnimationFrame

requestAnimationFrame是一个高性能的API,它可以根据屏幕的刷新率来同步动画的帧率,从而保证动画的流畅度。应尽量使用requestAnimationFrame来控制动画的播放和暂停。

减少重绘和重排

重绘和重排是导致动画卡顿的主要原因之一。可以通过减少不必要的样式计算和布局更新来减少重排和重绘。例如,避免在动画过程中频繁改变元素的布局或大小,尽可能使用transform属性代替top、left等属性,因为transform属性的改变不会触发重排。

避免使用过多的box-shadow和gradients

box-shadow和gradients会消耗大量的GPU资源,特别是在移动设备上。如果可以,尽量避免在动画元素上使用它们,或者尽量减少它们的数量和复杂性。

合理使用CSS选择器

复杂的CSS选择器会导致浏览器进行大量的样式计算,从而影响动画性能。应尽量避免使用过于复杂的选择器,或者尽量减少它们的数量和使用频率。

优化关键帧动画

对于关键帧动画,可以通过合理地拆分和组织关键帧来减少动画的复杂度,从而提高性能。例如,将多个动画拆分成多个独立的动画,或者将一些不重要的动画移到非关键帧中。

四、CSS动画库

随着前端开发的发展,出现了一系列独立的CSS动画库,这些库旨在提供更丰富的特性、更简洁的API、更好的性能和更好的开发体验。

  • Animate.css:一款开箱即用的跨浏览器动画库,适用于web项目。非常适合与效果增强、主页、滑块和操作引导提示。
  • Magic Animation:一组简单的动画,可包含在web或app项目中,提供具有特殊效果的CSS3动画。
  • Animista: 一个在线CSS动画生成器,可以在网站上选择预定义的动画类型和参数,然后生成相应的CSS代码。
  • Cssanimation.io: 一个在线CSS动画代码生成器,可以选择不同的动画效果,如淡入淡出、滑动等,并设置动画的持续时间和延迟时间。
  • Vivify:一个CSS动画库,提供了许多实用的动画效果类,可以方便地应用于网页元素上。它扩展了Animate CSS,不仅提供了类似的动画效果,还增加了一些额外的类和功能。使用Vivify,可以通过简单的类名来控制动画的持续时间和延迟时间等参数。

五、使用场景

原生CSS动画和CSS动画库各有适用场景,选择哪种主要取决于项目的具体需求。

原生CSS动画使用场景

  1. 简单的动画效果: 对于一些基本的、简单的动画效果,如淡入淡出、位移等,原生CSS动画足够满足需求。
  2. 性能优势: 原生CSS动画通常能够充分利用浏览器的硬件加速,性能较好。对于轻量级的动画,避免引入额外的库可以提高性能。
  3. 低维护成本: 对于小型项目或者仅有一些简单动画的项目,使用原生CSS动画可以减少依赖,降低维护成本。
  4. 响应式设计: 对于一些基于媒体查询实现的响应式动画,原生CSS动画更容易集成到响应式设计中。

CSS动画库使用场景

  1. 丰富的动画效果: CSS动画库通常提供了大量的动画效果,尤其是一些复杂的、专业设计的效果,可以方便地应用于项目。
  2. 快速开发: 在快速开发周期内,使用动画库可以减少编写和调试动画代码的时间,提高开发效率。
  3. 跨浏览器兼容性: 动画库通常经过测试和优化,能够解决不同浏览器之间的兼容性问题,减少开发者的兼容性工作。
  4. 复杂场景和交互性: 当项目需要复杂的交互动画、复合动画或需要在多个元素之间同步动画时,使用动画库更为方便。
  5. 动画的控制: 一些动画库提供了更高级的控制机制,例如暂停、恢复、反向播放等功能,使得动画更易于管理。

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

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

相关文章

YOLOv5姿态估计:HRnet实时检测人体关键点

前言&#xff1a; Hello大家好&#xff0c;我是Dream。 今天来学习一下利用YOLOv5进行姿态估计&#xff0c;HRnet与SimDR检测图片、视频以及摄像头中的人体关键点&#xff0c;欢迎大家一起前来探讨学习~ 本文目录&#xff1a; 一、项目准备1Pycharm中克隆github上的项目2.具体步…

森林消防泵:及时扑灭林火,保护森林生态平衡

在大自然中&#xff0c;森林是我们宝贵的自然资源&#xff0c;它们为我们提供氧气、净化空气、保持水土&#xff0c;还是许多动植物的家园。然而&#xff0c;森林火灾却时常威胁着这片绿色宝地的安全。为了保护森林生态环境&#xff0c;我们需要及时扑灭林火。而恒峰智慧科技研…

PhotoMaker, 腾讯开源人像图形处理

腾讯于昨天开源一款人像图形处理项目&#xff0c;项目地址&#xff1a;github.com/TencentARC/PhotoMaker 项目演示地址&#xff1a;https://huggingface.co/spaces/TencentARC/PhotoMakerhttps://huggingface.co/spaces/TencentARC/PhotoMaker-Style 演示效果&#xff1a; 项…

48-DOM

1.DOM基础 Document Object Module,文档对象模型,window对象,document文档,都可以获取和操作 1)文档节点 2)属性节点(标签内的属性href,src) 3)文本节点(标签内的文字) 4)注释节点 5)元素节点(标签) 2.获取元素节点 2.1通过标签名获取 <p>1</p><…

数字图像处理常用算法的原理和代码实现详解

本专栏详细地分析了常用图像处理算法的数学原理、实现步骤。配有matlab或C实现代码&#xff0c;并对代码进行了详细的注释。最后&#xff0c;对算法的效果进行了测试。相信通过这个专栏&#xff0c;你可以对这些算法的原理及实现有深入的理解&#xff01;   如有疑问&#xf…

在window宿主机访问WSL2内部署的服务

目录 在window宿主机访问 WSL2 内部署的服务&#xff08;其他&#xff09;在 WSL2 内查看 windows&#xff08;宿主机&#xff09;的IP地址 windows内置了Linux系统&#xff08;WSL&#xff09;。 在window宿主机访问 WSL2 内部署的服务 在WSL下部署的项目&#xff0c;比如端口…

新喜报,新希望!英码科技荣登“2023年广州拟上市领头羊TOP50企业榜单”

近日&#xff0c;广州市资本市场融资对接服务平台启动仪式暨2023年拟上市企业“领头羊”评选总结活动成功举办。活动现场发布了2023年广州“拟上市领头羊TOP 50 企业榜单”、“最受资本关注TOP10榜单”、“最强科创TOP10榜单”、“最具成长TOP10榜单”并为企业颁发牌匾&#xf…

烟火检测/周界入侵/视频智能识别AI智能分析网关V4如何配置ONVIF摄像机接入

AI边缘计算智能分析网关V4性能高、功耗低、检测速度快&#xff0c;易安装、易维护&#xff0c;硬件内置了近40种AI算法模型&#xff0c;支持对接入的视频图像进行人、车、物、行为等实时检测分析&#xff0c;上报识别结果&#xff0c;并能进行语音告警播放。算法可按需组合、按…

Abp vNext(三)数据迁移

文档版本&#xff1a;7.0 官方文档给的数据迁移的方式是这样的&#xff0c; 第一步 在 Acme.BookStore.EntityFrameworkCore 目录打开命令行终端输入以下命令: dotnet ef migrations add Created_Book_Entity 第二步 运行 Acme.BookStore.DbMigrator 应用程序来更新数据库…

基于环视鱼眼相机的全景拼接

本文主要记录基于环视鱼眼相机的全景拼接过程中遇到的问题及其解决思路 代码来源&#xff1a;https://github.com/Leooncode/surround-view-system-introduction/blob/master/doc/doc.md 1、针对多个鱼眼相机连接问题 鱼眼相机为USB摄像头&#xff0c;与网络摄像头采集方式不同…

高级IO(结尾总结)

五种IO模型 阻塞IO&#xff1a; 在内核将数据准备好之前, 系统调用会一直等待. 所有的套接字, 默认都是阻塞方式 这也是最常见的IO模型&#xff0c;阻塞流程按上图所示 非阻塞IO&#xff1a; 如果内核还未准备好数据报&#xff0c;也不会阻塞而是直接返回&#xff0c;并且返回…

认识Linux指令之 “tar” 指令

01.tar指令&#xff08;重要&#xff09; 打包/解包&#xff0c;不打开它&#xff0c;直接看内容 tar [-cxtzjvf] 文件与目录 .... 参数&#xff1a; -c &#xff1a;建立一个压缩文件的参数指令(create 的意思)&#xff1b; -x &#xff1a;解开一个压缩文件的参数指令&am…

Java异常处理--异常处理的方式2:throws

文章目录 一、方式2&#xff1a;声明抛出异常类型&#xff08;throws&#xff09;二、throws基本格式三、 throws 使用举例&#xff08;1&#xff09;针对于编译时异常1、案例12、案例2 &#xff08;2&#xff09;针对于运行时异常 四、 方法重写中throws的要求&#xff08;1&a…

深入了解指针(一)

前言 指针可是数据结构的基础&#xff0c;其内容及重要又繁多&#xff0c;之前没有时间整理出来&#xff0c;现在放假了怎么说也要写一个&#xff0c;既是对前面的总结和梳理&#xff0c;也可以用来以后的查找知识&#xff0c;ok&#xff0c;废话不多&#xff0c;直接启动。 …

网络文件共享服务 FTP

一、存储类型 存储类型分为三种 直连式存储&#xff1a;Direct-Attached Storage&#xff0c;简称DAS 存储区域网络&#xff1a;Storage Area Network&#xff0c;简称SAN&#xff08;可以使用空间&#xff0c;管理也是你来管理&#xff09; 网络附加存储&#xff1a;Network…

kafka系列(二)

本章承接kafka一内容&#xff0c;文章在本人博客主页都有&#xff0c;可以自行点击浏览。 幂等性 请求执行多次&#xff0c;但执行的结果是一致的。 如果&#xff0c;某个系统是不具备幂等性的&#xff0c;如果用户重复提交了某个表格&#xff0c;就可能会造成不良影响。例如…

SecureCRT7中文版安装资源,一键安装

SecureCRT 7 是一款功能强大的终端仿真软件&#xff0c;主要用于安全地远程访问和管理各种网络设备和服务器。 它支持多种协议&#xff0c;如 SSH、Telnet、Rlogin 等&#xff0c;可以连接到不同类型的设备&#xff0c;包括 Unix/Linux 服务器、网络设备、虚拟机等。通过使用 …

黑马程序员JavaWeb开发|案例:tlias智能学习辅助系统(5)登录认证

指路&#xff08;1&#xff09;&#xff08;2&#xff09;&#xff08;3&#xff09;&#xff08;4&#xff09;&#x1f447; 黑马程序员JavaWeb开发|案例&#xff1a;tlias智能学习辅助系统&#xff08;1&#xff09;准备工作、部门管理_tlias智能学习辅助系统的需求分析-CS…

C++的构造析构函数

前言 本篇文章介绍C的构造函数和虚构函数 写在前面 因为介绍构造函数基本都会设计虚函数和虚基类的使用&#xff0c;可以参考之前的文章&#xff1a; C中的虚函数 C的虚基类 构造函数 每个类都分别定义了它的对象被初始化的方式&#xff0c;类通过一个或几个特殊的成员函数…

蓝牙运动耳机哪款好用?运动用哪种耳机好?2024运动蓝牙耳机推荐

​户外活动、健身运动还是激烈跑步&#xff0c;一款出色的运动耳机能够提升整体运动体验。这些耳机不仅具备出色的防汗和稳定佩戴性能&#xff0c;更通过强劲音质为你注入动力。让我们一同探索几款在各种运动场景中脱颖而出的运动耳机吧。 1.南卡开放式耳机&#xff08;00压&a…