只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇

这篇具有很好参考价值的文章主要介绍了只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

前言

Transition

属性

简写

进阶用法

Animations

@keyframes关键帧

from&to

animation动画

属性

简写

进阶用法

贝塞尔曲线(Bezier Curve)

总结


前言

实现动画效果是前端提升用户体验的重要一环,从CSS动画到JS动画帧,每种技术都有其独特的优势和适用场景,本篇文章将与大家分享浏览器CSS的原生动画技术

在css中有两种动画形式,分别是Transition(过渡,元素从一种样式逐渐变成另一种样式)和Animation(动画,元素通过几个步骤定义样式改变)

Transition

transition属性用来定义元素何时启动整个过渡的开始、结束状态,以及每个过渡属性的值变化规则。它是一种简单、易于使用的CSS技术,可以产生绚丽的过渡效果,从而增加网页的交互性和用户吸引力

属性

transition-property:transition控制哪个属性,默认all,可以是多个属性,用逗号分隔。

transition-duration:transition的持续时间,默认0,单位为秒(s)或者毫秒(ms)。

transition-timing-function:设置transition的速度曲线(后文的贝塞尔曲线),默认ease渐进。可以是linear线性,ease渐进,ease-in加速,ease-out减速等。

transition-delay:控制transition何时开始(延迟),默认0,单位为秒(s)或者毫秒(ms)。

下面是一个基本写法,过渡时间1秒,延迟1秒,针对left属性生效,过渡速度曲线是ease-out

transition-duration: 1s;
transition-property: left;
transition-timing-function: ease-out;
transition-delay: 1s;

简写

上面的多个子属性可以通过下面的简写达到相同的效果。

transition: transition-property transition-duration transition-timing-function transition-delay;

tips:参数顺序无影响,参数有两个时间,先写的是duration,后写的是delay

来看看下面这个例子,我们通过hover触发过渡动画,针对left属性生效,过渡时间0.5秒,延迟一秒执行,动画效果是匀速,也就是hover后整个过程是1.5秒

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title></title>
    <style>
      html,
      body {
        width: 100%;
        height: 100%;
        position: relative;
      }
      .box {
        width: 200px;
        height: 200px;
        left: 0;
        position: absolute;
        background: lightblue;
      }
      .box:hover {
        left: 100px;
        transition: left 0.5s linear 1s;
      }
    </style>
  </head>
  <body>
    <div class="box"></div>
  </body>
</html>

效果如下

只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划

进阶用法

  • transition-property可以设置all适用于全部属性,当存在多个属性需要设置成不同的过渡效果时可以使用逗号隔开,比如
.box:hover {
  left: 100px;
  width: 400px;
  transition: left 1s linear 1s, width 1s ease-in-out;
}

只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划

  • 如果想让触发器失效时(取消hover操作)的动画不那么生硬,可以考虑在原有样式中加上同样的过渡,我们使用之前的CSS变量将过渡动画使用变量定义一下,方便复用
html,
body {
  width: 100%;
  height: 100%;
  position: relative;
  --box-transition: left 1s linear 1s, width 1s ease-in-out;
}
.box {
  width: 200px;
  height: 200px;
  left: 0;
  position: absolute;
  background: lightblue;
  transition: var(--box-transition);
}
.box:hover {
  left: 100px;
  width: 400px;
  transition: var(--box-transition);
}

只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划

  • transition-timing-function有以下常用方法:
  1. linear:匀速线性
  2. ease:规定过渡效果,先缓慢地开始,然后加速,然后缓慢地结束
  3. ease-in:规定缓慢开始的过渡效果
  4. ease-out:规定缓慢结束的过渡效果
  5. ease-in-out:规定开始和结束较慢的过渡效果
  6. steps(int, start | end):指定带有两个参数的步进函数。第一个参数指定函数中的间隔数。第二个参数指的是从每步的开始还是结束计算,可以参考下面这张图
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划
    效果可以参考下面的gif:
    transition-timing-function: steps(3, end)
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划
    transition-timing-function: steps(3, start)
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划
  7. step-start:相当于steps(1, start)

  8. step-end:相当于steps(1, end)

  9. cubic-bezier():贝塞尔曲线函数,可以参考这个网站进行在线调试

Animations

说完了CSS的过渡,我们来看看animations动画,它通过设置animation(动画)属性与@keyframes(关键帧)进行使用。

语法如下

@keyframes关键帧

关键帧有几种定义方式,用来声明不同阶段的样式属性

from&to

from属性可以设置起始样式,to则是设置结束样式,from和to都可以单独设置。我们把整个动画拆分成多个帧,第一帧的效果就是from,最后一帧就是to。

@keyframes animationname {
  from {
    /* 开始样式 */
  }
  to {
    /* 结束样式 */
  }
}
@keyframes animationname1 {
  from {
    /* 开始样式 */
  }
}
@keyframes animationname2 {
  to {
    /* 结束样式 */
  }
}

百分比

百分百的写法可以理解为将一个动画分为多个关键点,比如整个动画总耗时是4秒,则每秒对应的样式可以使用下面的语句

@keyframes myAnimation {
  0% {
    left: 10px;
  }
  25% {
    left: 40px;
  }
  50% {
    left: 80px;
  }
  100% {
    left: 100px;
  }
}

animation动画

上面我们讲述了关键帧的定义,如果需要定义多段动画或者无规律的动画,关键帧就显得很重要。那么定义完动画后我们应该如何使用呢?这就离不开接下来的animation动画属性了

属性

和transition一样animation也有许多可配置的属性

  1. animation-name:使用@keyframes定义的动画名。
  2. animation-duration:动画的持续的时间。属性同transition-duration
  3. animation-timing-function:动画的速度曲线。属性同transition-timing-function
  4. animation-delay:指定动画延迟的时间。属性同transition-delay
  5. animation-iteration-count:指定动画循环的次数。设置infinite表示无限循环,也可以设置正整数,表示次数
  6. animation-direction:指定动画运动方向。理解为往复运动
  7. animation-fill-mode:指定动画结束时的状态。
  8. animation-play-state:指定是否播放或暂停动画。paused是暂停,running是运行

简写

animation可以将上面的配置简写在一个样式中

animation: animation-name animation-duration animation-timing-function animation-delay animation-iteration-count animation-direction animation-fill-mode animation-play-state

tips:和过渡一样,参数顺序不固定,其中有两个时间,先写的是duration,后写的是delay

下面是一个例子,其中配置的含义是使用myAnimation动画,延迟一秒执行匀速动画,动画的过程是2秒,往复执行3次,完成后不重置位置

@keyframes myAnimation {
  from {
    left: 0px;
  }
  to {
    left: 100px;
  }
}
.box-move {
  animation: myAnimation 2s linear 1s 3 alternate forwards running;
}

效果如下

只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划

进阶用法

由于2、3、4属性与transition一样,所以介绍一下上面的6、7、8属性

  • animation-direction用于控制动画的方向,如果一段动画的过程是A->B,默认是normal,表示A->B;设置为reverse表示B->A;
    当animation-iteration-count设置为infinite时:
    alternate表示A->B->A->B......,效果如下:
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划
    alternate-reverse表示B->A->B->A......,效果如下:
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划
  • animation-fill-mode是指设置第一帧的前一帧或最后一帧的后一帧的状态。
    当设置为forwards表示动画最后一帧保持现状不会重置到第一帧;
    设置为backwards时,动画的前一帧(第-1帧)与第一帧保持一样;
    设置为both时表示同时具备forwards和backwards的效果
  • animation-play-state:指定是否播放或暂停动画。paused是暂停,running是运行。
    常用的操作是通过js控制动画暂停和播放
    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="UTF-8" />
        <title></title>
        <style>
          html,
          body {
            width: 100%;
            height: 100%;
            position: relative;
            transition: left 3s linear;
          }
          .box {
            width: 200px;
            height: 200px;
            top: 50px;
            position: absolute;
            background: lightblue;
          }
          @keyframes myAnimation {
            from {
              left: 0px;
            }
            to {
              left: 100px;
            }
          }
          .box-move {
            animation: myAnimation 1s infinite forwards alternate;
          }
        </style>
      </head>
      <body>
        <div class="box box-move"></div>
        <button id="play_pause">暂停/继续</button>
        <script>
          const btn = document.querySelector("#play_pause");
          const box = document.querySelector(".box");
          btn.addEventListener("click", () => {
            const { style } = box;
            if (style.animationPlayState === "paused") {
              return (style.animationPlayState = "running");
            }
            style.animationPlayState = "paused";
          });
        </script>
      </body>
    </html>
    

    效果如下
    只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇,CSS,JavaScript,前端动画,前端,javascript,面试,css,原力计划

贝塞尔曲线(Bezier Curve)

贝塞尔曲线与前端动画能碰撞出怎样的火花呢?可以说这二者关系非常紧密,前端大部分动画都是采用匀速动画,效果比较生硬。如果想让动画看起来更平滑,更符合人眼观察,就需要用到贝塞尔曲线

贝塞尔曲线是由一系列控制点所组成的曲线。它的形状由这些控制点所确定,而不是像多项式曲线一样由特定的数学公式来描述。

一个贝塞尔曲线通常由三个或更多的控制点组成。当控制点的数量为三个时,它被称为二次贝塞尔曲线;为四个时,它被称为三次贝塞尔曲线;以此类推。

使用控制点来定义贝塞尔曲线的好处是,可以直接控制曲线的形状,同时可以轻松地修改这些点,而不需要重新计算整个曲线。

我们可以在这个网站对贝塞尔曲线(三次贝塞尔曲线)进行模拟操作

总结

本文从CSS的两大动画属性与大家分享了使用transition达到样式变化过渡的效果,以及animation动画效果,其中transition适合单一的样式属性过渡,其优势在于兼容性好、性能高,能够平滑地过渡样式的变化;而animations使用@keyframes和animation属性实现复杂的动画效果,具有更高的灵活性,可以定义任意的关键帧和时间线,并实现任意属性的变化动画。在实际开发中我们可以根据项目需求选择合适的技术,让它们发挥最大的作用

以上就是文章全部内容了,希望能够对你有帮助,相关问题可以评论或者私信。最后如果觉得文章不错的话,还望三连支持一下博主,感谢!

相关代码:myCode: 基于js的一些小案例或者项目 - Gitee.com文章来源地址https://www.toymoban.com/news/detail-577904.html

到了这里,关于只会用插件可不行,这些前端动画技术同样值得收藏-CSS篇的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 你知道HashMap有几种吗?不要只会用最简单的奥!

    这秋意是越来越近了,这思念就开始泛滥… 在 Java 中,有多种哈希映射(HashMap)的实现,每种都有不同的特点和适用场景。以下是几种常见的哈希映射实现: HashMap : 介绍 : HashMap 是 Java 标准库中的哈希映射实现。它使用链地址法(chaining)来解决哈希冲突,并在大多数情

    2024年02月07日
    浏览(36)
  • 别再只会使用简单的ping命令了,Linux中这些高级ping命令可以提高工作效率!

    当你需要测试网络连接或者诊断网络问题时,ping命令是一个非常有用的工具。除了基本的用法,ping还有一些高级用法,可以帮助你更好地使用它。 首先,让我们回顾一下ping的基本用法。ping命令用于测试与另一台计算机的连接是否正常。以下是基本的ping命令: 其中, host

    2023年04月18日
    浏览(57)
  • 这些开源自动化测试框架,会用等于白嫖一个w

    作者:黑马测试 链接:https://www.zhihu.com/question/19923336/answer/2585952461 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。   随着计算机技术人员的大量增加,通过编写代码来进行测试成为一种更为高效的测试方式,由此而诞生了以计算机语

    2024年02月02日
    浏览(51)
  • 前端使用jsencrypt实现RSA公钥解密——uniapp同样适用

    在node_modules目录下,根据如下路径找到rsa.js文件 jsencrypt/lib/lib/jsbn/rsa.js 1、修改 RSAKey.prototype.decrypt 方法(将doPrivate改为doPublic) 2、修改 rsa.js文件下的pkcs1unpad2方法 3、保存文件即可 保存修改后的rsa.js文件,一般情况下不需要重新编译也可生效,如有问题就重新build或serve一下

    2024年02月06日
    浏览(51)
  • 3D建模完成以后,如何用编程语言控制这些模型的展示和动画

    完成 3D 建模后,需要使用一些图形编程库来控制模型的展示和动画。下面是一些常用的图形编程库: OpenGL:OpenGL 是一个跨平台的图形编程接口,可以使用多种编程语言进行开发,比如 C/C++,Python,Java 等。OpenGL 提供了强大的图形渲染能力,可以用来绘制各种 2D 和 3D 图形,

    2024年02月04日
    浏览(32)
  • 如果让你实现实时消息推送你会用什么技术?轮询、websocket还是sse

    在日常的开发中,我们经常能碰见服务端需要主动推送给客户端数据的业务场景,比如_数据大屏的实时数据_,比如_消息中心的未读消息_,比如_聊天功能_等等。 本文主要介绍SSE的使用场景和如何使用SSE。 学习就完事了 我们常规实现这些需求的方案有以下三种 轮询 websock

    2024年03月19日
    浏览(47)
  • 一个合格(优秀)的前端都应该阅读这些文章

    的确,有些标题党了。起因是微信群里,有哥们问我,你是怎么学习前端的呢?能不能共享一下学习方法。一句话也挺触动我的,我真的不算是什么大佬,对于学习前端知识,我也不能说是掌握了什么捷径。当然,我个人的学习方法这篇文章已经在写了,预计这周末会在我个

    2024年02月08日
    浏览(44)
  • 一个合格(优秀)的前端都应该阅读这些文章(coding)

    原文地址:Nealyang/PersonalBlog 的确,有些标题党了。起因是微信群里,有哥们问我,你是怎么学习前端的呢?能不能共享一下学习方法。一句话也挺触动我的,我真的不算是什么大佬,对于学习前端知识,我也不能说是掌握了什么捷径。当然,我个人的学习方法这篇文章已经在

    2024年02月08日
    浏览(38)
  • 自学web前端觉得好难,可能你遇到了这些困境

    好多人跟我说上学的时候也学过前端,毕业了想从事web前端开发的工作,但自学起来好难,快要放弃了,所以我总结了一些大家遇到的困境,希望对你会有所帮助。   目录 1.  意志是否坚定 2. 没有找到合适自己的老师 3. 为了找到工作,啥都想学  4. 学习途中遇到问题怎么办

    2024年02月02日
    浏览(99)
  • 【前端修炼场】 — 这些标签你学会了么?快速拿下 “hr”

    此文为【前端修炼场】第四篇,上一篇文章链接: 上一篇 在此之前,诸位道友已经接触不少的标识符了,并且对于VSCode肯定也有诸多的不满!你是否也疑惑,为什么在VSCode里面换行或者空格都不会体现在网页上,这也太不方便了,其实还有更不方便的,我们许多特殊符号也

    2024年01月24日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包