代码编织梦想

微信搜索 【大迁世界】, 我会第一时间和你分享前端行业趋势,学习途径等等。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

我们每天都在网上摸鱼,作为前端开发人员,网站上微妙的细节变化通过比别人会更关注。我一直注意到的一件事是网站上的动画的流畅性。动画对于用户体验来说是非常好的,有时我们可以一些有趣的动画来留住用户。

创建高级动画听起来是一个很难的话题,但好消息是,在CSS中,可以将多个简单的动画相互叠加,以创建一个更复杂的动画

在这节课中,我们会学习如下几点:

  • 什么是贝塞尔曲线,以及如何用一行CSS来创建一个 "复杂"的动画
  • 如何将动画相互叠加以创建一个高级动画
  • 如何通过应用上面学到的两点来创建一个过山车动画

什么是贝塞尔曲线

CSS中的 cubic-bezier 函数是一个缓动函数,可以让我们完全控制动画在时间上的表现。下面是官方的定义:

贝塞尔缓动函数是一种由四个实数定义的缓和函数,指定了贝塞尔曲线的两个控制点P1P2,其端点P0P3分别固定在(0, 0)和(1, 1)P1P2x坐标被限制在[0, 1]范围内。

在这里插入图片描述

什么是缓动函数?

线性曲线

想象两个点P0P1,其中P0是动画的起点,P1是结束点。现在想象另一个点在两点之间线性移动,如下所示

在这里插入图片描述

这就是所谓的线性曲线,也是最简单的动画。

二次贝塞尔曲线

如下图所示,有三个点。P0、P1和P2。我们想让动画从P0移动到P2。在这种情况下,P1是一个控制点,控制动画的曲线。

在这里插入图片描述

二次方贝塞尔概念:

  • 在P0和P1之间以及P1和P2之间(用灰线表示)连接虚线

  • 点Q0沿着P0和P1之间的直线移动。同时,点Q1沿着P1和P2之间的直线移动

  • 在Q0和Q1之间连接一条虚线(用绿线表示)

  • 在Q0和Q1开始移动的同时,点B开始沿着绿线移动,B点所走的路径就是动画路径

在这里插入图片描述

请注意,Q0、Q1和B不以相同的速度移动。它们都必须在同一时间开始,并在同一时间完成它们的路径。因此,每一个点都是根据它所移动的线长以适当的速度移动的。

三次贝塞尔曲线

三次贝塞尔曲线由4个点组成。P0, P1, P2和P3。动画开始于P0,结束于P3。P1和P2是我们的控制点。

在这里插入图片描述

三次贝赛尔的工作原理如下:

  • 在(P0, P1)、(P1, P2)和(P2, P3)之间连接虚线,由灰线表示
  • 点Q0、Q1和Q2分别沿直线(P0,P1)、(P1,P2)和(P2,P3)移动
  • 在(Q0, Q1)和(Q1, Q2)之间连接虚线,它们由绿线表示。
  • 点R0和R1分别沿直线(Q0, Q1)和(Q1, Q2)移动
  • 连接R0和R1之间的线(用蓝线表示)
  • 最后,B点沿着R0和R1之间的连接线移动,B点所走的路径就是动画路径

在这里插入图片描述

如果你想更好地了解三次体贝塞尔的工作原理,建议你看看这个desmos链接。玩玩控制点,看看动画如何随时间变化。(注意,链接中的动画是由黑线表示的)。

叠加动画

有很多步骤的大动画可以被分解成多个小动画。在 css 中,通过添加animation-delay属性来实现这一点。计算延迟很简单,把你要计算动画延迟的那个动画之前的所有动画的时间加起来。

例如:

animation: movePointLeft 4s linear forwards, movePointDown 3s linear forwards;

这里,我们有两个动画,movePointLeftmovePointDownmovePointLeft的动画延迟是零,因为它是我们想先运行的动画。movePointDown的动画延迟是4秒,因为movePointLeft将在这段时间后完成。

因此,animation-delay属性:

animation-delay: 0s, 4s;

注意,如果有两个或更多的动画同时开始,它们的动画延迟将是一样的。此外,当你计算即将开始的动画的延迟时,把它们视为一个动。例如 :

animation: x 4s linear forwards, y 4s linear forwards, jump 2s linear forwards;

假设xy同时开始。在这种情况下,xy的动画延迟都将为零,而 jump 动画的延迟将为4秒(而不是8秒!)。

animation-delay: 0s, 0s, 4s;

创建过山车

掌握了上面的知识,是时候应用一下了。

了解动画

过山车路径由三部分组成:

  • 滑动部分
  • 循环部分
  • 还会有一些动画,在上面的两个动画之间创造水平空间

在这里插入图片描述

我们将首先创建一个简单的球,作为我们过山车的 “车”。

hmtl 部分:

<div id="the-cart" class="cart"></div>

css 部分:

.cart {
  background-color: rgb(100, 210, 128);
  height: 50px;
  width: 50px;
  border: 1px solid black;
  border-radius: 50px;
  position: absolute;
  left: 10vw;
  top: 30vh;
}

滑动部分

创建小球滑动的部分可以用cubic-bezier函数来完成! 这个动画是由2个动画组成的,一个是沿x轴的动画,另一个是沿y轴的动画。X轴动画是一个沿X轴的普通线性动画。它的关键帧如下:

@keyframes x {
  to {
    left: 40vw;
  }

将其添加到球路径的 animation 属性中,如下所示

animation: x 4s linear forwards

y轴动画是我们将使用cubic-bezier函数的部分。首先定义动画的关键帧。我们希望起始点和结束点之间的差异很小,以至于球达到的高度几乎相同。

@keyframes y {
  to {
    top: 29.99vh;
  }
}}

现在让我们来思考一下cubic-bezier函数。我们希望我们的路径先向右缓慢移动,然后当它滑动时,它应该走得更快。

在这里插入图片描述

  • 向右缓慢移动意味着$P1$将沿x轴移动。所以,我们知道它是在(V,0)。

  • 我们需要选择一个合适的V,使我们的动画缓慢地向右移动,但又不能太多,以免占用整个空间。在这种情况下,我发现0.55最适合。

  • 为了达到滑动效果,我们需要将P2Y轴下移(负值),所以P2=(X,-Y)

    • Y应该是一个大值。在这种情况下,我选择 Y=5000
    • 为了得到X,我们知道我们的动画速度在滑动时应该更快,在再次上升时应该更慢。所以,X越接近于零,动画在滑动时就越陡峭。在这种情况下,让X = 0.8

现在,我们得到了一个cubic-bezier函数:

cubic-bezier(0.55, 0, 0.2, -800).

为动画属性添加关键帧:

animation: x 4s linear forwards,
    y 4s cubic-bezier(0.55, 0, 0.2, -5000) forwards;

这是我们动画的第一部分,所以动画延迟为零。我们应该添加一个animation-delay属性,因为从下面的动画开始,动画的开始时间将与第一个动画不同。

animation-delay: 0s, 0s;

地址:https://codepen.io/smashingmag/pen/VwxXBQb

在这里插入图片描述

添加水平空间

在做循环之前,球应该沿着X轴移动一小会儿,所以两个动画之间有空间。

定义关键帧

@keyframes x2 {
  to {
    left: 50vw;
  }
}

把它添加到 animation 属性中:

animation: x 4s linear forwards,
    y 4s cubic-bezier(0.55, 0, 0.2, -5000) forwards, x2 0.5s linear forwards;

这个动画应该在滑动动画之后开始,而滑动动画需要4秒,因此,动画延迟将是4秒。

animation-delay: 0s, 0s, 4s;

地址:https://codepen.io/smashingmag/pen/dyemExY

在这里插入图片描述

循环部分

要在CSS中创建一个圆(循环),我们需要把圆移到循环的中心,然后从那里开始做动画。圆的半径是100px,所以我们把圆的位置改为top: 20vh30是期望的半径(这里是10vh))。然而,这需要在滑动动画完成后发生,所以我们将创建另一个持续时间为0秒的动画,并添加一个合适的动画延迟。

关键帧:

@keyframes pointOfCircle {
  to {
    top: 20vh;
  }
}

添加到 animation 动画中:

animation: x 4s linear forwards,
    y 4s cubic-bezier(0.55, 0, 0.2, -5000) forwards, x2 0.5s linear forwards,
    pointOfCircle 0s linear forwards;

添加动画延迟, 4.5s:

animation-delay: 0s, 0s, 4s, 4.5s;

循环本身

创建一个循环动画:

  • 创建一个关键帧,将球移回原来的位置,然后旋转球。
@keyframes loop {
  from {
    transform: rotate(0deg) translateY(10vh) rotate(0deg);
  }
  to {
    transform: rotate(-360deg) translateY(10vh) rotate(360deg);
  }
}

添加到 animation 中:

animation: x 4s linear forwards,
    y 4s cubic-bezier(0.55, 0, 0.2, -5000) forwards, x2 0.5s linear forwards,
    pointOfCircle 0s linear forwards, loop 3s linear forwards;

添加动画延迟,这里是4.5s:

animation-delay: 0s, 0s, 4s, 4.5s, 4.5s;

地址:https://codepen.io/smashingmag/pen/mdLxZdR

在这里插入图片描述

添加水平空间

快完成了,最后 只需要在动画之后沿着x轴移动球,这样球就不会像上图中那样在循环之后完全停止。

关键帧:

@keyframes x3 {
  to {
    left: 70vw;
  }
}

添加到 animation 中:

animation: x 4s linear forwards,
    y 4s cubic-bezier(0.55, 0, 0.2, -800) forwards, x2 0.5s linear forwards,
    pointOfCircle 0s linear forwards, loop 3s linear forwards,
    x3 2s linear forwards;

加上适当的延迟,这里是7.5s:

animation-delay: 0s, 0s, 4s, 4.5s, 4.5s, 7.5s;

地址:https://codepen.io/smashingmag/pen/wvjmLKp

在这里插入图片描述

总结

在本节中,我们介绍了如何结合多个关键帧来创建一个复杂的动画路径。我们还介绍了贝塞尔以及如何使用它们来创建你自己的缓动函数。建议大家自己多多动手,才能更好的掌握 css 动画。

来源:https://www.smashingmagazine.com/2022/10/advanced-animations-css/

编辑中可能存在的bug没法实时知道,事后为了解决这些bug,花了大量的时间进行log 调试,这边顺便给大家推荐一个好用的BUG监控工具 Fundebug

交流

有梦想,有干货,微信搜索 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试完整考点、资料以及我的系列文章。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq449245884/article/details/128011005

python高级-前端-01-html和css_mysteryflower的博客-爱代码爱编程_python高级讲义/html+css

课程介绍 前端开发系统化学习教程,包括html、css、PC端及移动端布局技巧、javascript、jquery、js特效制作、ajax前后台交互等。     前端开发概述 什么是前端开发? 前端开发也叫做web前端开发,它指的是基于web的互联网产品的页面(也可叫界面)开发及功能开发。 什么互联网产品? 互联网产品就是指网站为满足用户需

css3动画旋转动画_9个关于CSS动画的热门课程-爱代码爱编程

css3动画旋转动画 在网络的早期,动画因所有那些笨拙,复杂的效果而闻名,这些效果看起来不错,但加载速度很慢,使用起来常常令人困惑。 但是,如果以正确的方式使用动画,对于网站设计师来说,动画可能是一个绝佳的工具。 少量的,引人注目的动作是帮助用户解释界面并找到围绕您的网站或应用程序的一种好方法。 您是否掌握了使用CSS,JavaS

ios 文本动画_如何创建微妙的动画文本开口-爱代码爱编程

ios 文本动画 Have you ever seen subtle text openings and wondered how they came about? 您是否曾经看过微妙的文字开口并想知道它们是如何产生的? There’s so many of those out there, and it’s practically imp

10 个 GitHub 上超火的 CSS 技巧项目,找到写 CSS 的灵感!-爱代码爱编程

大家好,我是你们的 超级猫,一个不喜欢吃鱼、又不喜欢喵 的超级猫 ~ 如果 CSS 是女孩子,肯定如上图那样吧 ???? ~ 简介 一般人没事的时候刷刷朋友圈、微博、电视剧、知乎,而有些人是没事的时候刷刷 GitHub ,看看最近有哪些流行的项目。 久而久之,这差距就越来越大,因此总会有开源信息的不对称,有哪些优秀的前端开源项目值得学习的

如何在 JS 中判断数组是否包含指定的元素(多种方法)-爱代码爱编程

作者:Abhilash Kakumanu 译者:前端小智 来源:medium 点赞再看,微信搜索**【大迁世界】,B站关注【前端小智】**这个没有大厂背景,但有着一股向上积极心态人。本文 GitHub https://github.com/qq449245884/xiaozhi 上已经收录,文章的已分类,也整理了很多我的文档,和教程资料。

10 个 GitHub 上超火的 CSS 奇技淫巧项目,找到写 CSS 的灵感!-爱代码爱编程

大家好,我是你们的 超级猫,一个不喜欢吃鱼、又不喜欢喵 的超级猫 ~ 如果 CSS 是女孩子,肯定如上图那样吧 🤩 ~ 简介 一般人没事的时候刷刷朋友圈、微博、电视剧、知乎,而有些人是没事的时候刷刷 GitHub ,看看最近有哪些流行的项目。 久而久之,这差距就越来越大,因此总会有开源信息的不对称,有哪些优秀的前端开源项目值得学习的也不知道

Vue 3 生命周期完整指南-爱代码爱编程

highlight: a11y-dark theme: condensed-night-purple 作者:Michael Thiessen 译者:前端小智 来源:news 点赞再看,微信搜索**【大迁世界】,B站关注【前端小智】**这个没有大厂背景,但有着一股向上积极心态人。本文 GitHub https://github.com/q

CSS3 高级应用(过渡、变形、动画)、滤镜、精灵图、字体图标、CSS初始化、及相关技巧等-爱代码爱编程

文章目录 CSS3高级应用过渡变形动画CSS3滤镜精灵技术字体图标CSS初始化CSS相关技巧CSS三角CSS用户界面样式vertical-align属性应用溢出文字省略号显示 CSS3高级应用 在传统的Web设计中,当网页中需要显示动画或特效时,需要使用JavaScript脚本或者Flash来实现。在CSS3中,提供了对动画的强大支持,可以实

面试题整理|45个CSS面试题-爱代码爱编程

面试题整理|45个CSS面试题 一、初级CSS面试题二、中级CSS面试题三、进阶CSS面试题四《HTML5&CSS3还原美团外卖》移动端布局实战 CSS已成为Web设计不可或缺的一部分,它让web页面变得更加美观,更具设计感。在前端面试中,CSS面试题也占有一定比重。 本篇文章,将为大家分享45个和CSS相关的面试题及其解析,难度分

前端H5新增标签和CSS3高级-爱代码爱编程

文章目录 一、CSS3高级技巧1.精灵图2.字体图标3.CSS中的三角3.CSS用户界面样式4.vertical-align属性应用5.溢出的文字省略号显示6.常见布局技巧6.CSS初始化二、HTM5的新增特性1.新增的语义化标签2.新增的多媒体标签3.新增的input类型4.新增的表单属性三、CSS3的新增特性1.新增选择器2.CSS3盒子模型b

如何使用React创建视频和动画-爱代码爱编程

点击上方关注 TianTianUp,一起学习,天天进步 大家好,我是小弋。 分享的内容是: 如何使用 React Remotion 来创建视频的,如果你之前对视频很感兴趣的话,这篇文章可以参考。 正文 Remotion是一个最近推出的库,它允许您使用 React 创建视频和动态图形。作为一名 Web 开发人员,我发现它非常有趣,因为它为我们

HTML5+CSS、CSS3基础知识点总结-爱代码爱编程

一、选择器 选择器分为基础选择器和复合选择器两大类。 基础选择器由单个选择器组成基础选择器包括:标签选择器、类选择器、id 选择器和通配符选择器(*)标签选择器 优点 标签选择器可以把某一标签全部选择出来,快速为同类型标签设置统一样式。 缺点 不能设置差异化样式,只能选择全部当前标签。 id 选择器与类选择器的区别 类选择器可以被多个元素调用。

前端开发-CSS快速掌握上手知识详细总结-爱代码爱编程

01_CSS基础 前言 最准确的网页设计思路是把网页分成三个层次,即:结构层、表示层、行为层。 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-wsmkKve6-1637594225448)(images01_base/wps1.jpg)] HTML:结构层,Hyper Text Markup Language,超文本

掌握CSS3 核心-爱代码爱编程

学习目标 掌握CSS的基本概念和应用精通CSS选择符-众多高级选择器技术的核心选择器的权重和优先级选择器的命名定位和层叠上下文CSS绘制高级技巧CSS机制At-ruleCSS工作原理和性能优化CSS 的基本概念 CSS 是一种描述 HTML 文档样式的语言。 CSS 描述应该如何显示 HTML 元素。 css 实例 body { backgrou

10 个 web前端开发者必须要掌握的CSS 技巧-爱代码爱编程

英文 | https://medium.com/@nasyxrakeeb2/10-css-pro-tips-code-this-not-that-codipher-f94558e82756 翻译 | 杨小爱 CSS 是每个 Web 开发人项目中的重要组成部分。对于没有设计和 UI 的 Web 开发人员来说,一切都是不可能的。 因此,在使用

html5、css3_m0_68213303的博客-爱代码爱编程

1、H5 的新特性有哪些?C3 的新特性有哪些?(必会) H5 新特性 1、拖拽释放(Drap and drop) API ondrop 拖放是一种常见的特性,即抓取对象以后拖到另一个位置 在 HTML5 中,拖放是标准的一部分,任何元素都能够拖放 2、自定义属性 data-id 3、语义化更好的内

这几个 css 专业技巧,你在 10 分钟内即可学会-爱代码爱编程

 大厂技术  高级前端  Node进阶 点击上方 程序员成长指北,关注公众号 回复1,加入高级Node交流群 我在超过75000条的调查回复中发现,CSS的难度位居榜首,因为它是 Web 开发人员必须掌握和使用的技术,同时,也是他们觉得最痛苦的技术。并且他们还说CSS太混乱了,太难了。 甚至有人说CSS在设计上很糟糕,无法保护应用程序