찾다
웹 프론트엔드CSS 튜토리얼CSS로 애니메이션을 만드는 일반적인 기술을 설명하는 문서(컬렉션)

이전 글 "당신이 알아야 할 고급 JS 스킬(요약)"에서 고급 JS 스킬에 대해 알아보았습니다. 다음 기사에서는 CSS를 사용하여 애니메이션을 만드는 일반적인 기술을 소개합니다.

CSS로 애니메이션을 만드는 일반적인 기술을 설명하는 문서(컬렉션)

transition

CSS에는 transition 속성이 있습니다. 이 속성은 특정 CSS 속성의 변경 사항을 모니터링하고 속성 변경 제어를 통해 간단한 애니메이션 효과를 얻을 수 있습니다. transition属性,能够监听某个 CSS 属性的变化,通过属性变化的控制,实现简单的动画效果:

transition CSS 属性是 transition-property,transition-duration,transition-timing-function 和 transition-delay 的一个简写属性。 —— 引用自 MDN

html代码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .box {
        width: 200px;
        height: 50px;
        line-height: 50px;
        text-align: center;
        color: #fff;
        background: #000;
        border-radius: 4px;
        /* 使用 transition 侦听 CSS 属性变化 为其加上动画 */
        transition: background 1s ease-in-out 0.2s, color 3s, width 5s;
      }
      .box:hover {
        width: 400px;
        color: #000;
        background: #fff;
      }
    </style>
  </head>
  <body>
    <div>
      <div>鼠标悬浮查看效果</div>
    </div>
  </body>
</html>

动画效果点击此处查看 地址https://codepen.io/wjq990112/pen/PoqEemX

体验完了,现在来具体讲一下用法:

css代码

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

这样写你们估计看不懂,我们一条一条来拆解:

css代码

transition-property: background; /* 任何你需要侦听变化的 CSS 属性 */
transition-duration: 1s; /* 设定过渡动画的时长 */
transition-timing-function: ease-in-out; /* 设定过渡动画的效果 */
transition-delay: 0.2s; /* 设定触发动画的延迟 */

transition属性就是由上面的 4 条 CSS 属性组合而成。

第一第二个属性是必须项,用于指定侦听需要添加过渡动画的属性以及指定动画时长。

第三第四个属性为可选项,用于设定过渡动画的效果和延迟。

transition-timing-function的可选值详见

https://developer.mozilla.org/zh-CN/docs/Web/CSS/transition-timing-function

第一个属性还有 2 个特殊值:none:不对任何属性进行侦听 all:对所有属性进行侦听并为其添加过渡动画。

当省略第三个属性时,第二个时间项会被自动解析为动画效果延迟。

干说还是有点难理解,举个栗子吧:

css代码

transition: background 1s ease-in-out 0.2s; 

上面这个例子,就是前面的代码中的一部分。

意思是侦听background的变化,为其添加 1 秒的过渡动画,过渡动画的效果是慢开始慢结束,并在属性变化 0.2 秒后才开始执行。

那么上面代码中的这一段:

css代码

.box {
  width: 200px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  color: #fff;
  background: #000;
  border-radius: 4px;
  /* 使用 transition 侦听 CSS 属性变化 为其加上动画 */
  transition: background 1s ease-in-out 0.2s, color 3s, width 5s;
}
.box:hover {
  width: 400px;
  color: #000;
  background: #fff;
}

代码中的transition属性分别为background``color``width加上了过渡动画,当class=box的标签的这三个属性发生变化时,就回自动为其加上默认或指定的动画效果。

接下来我们就用它来做一些进阶的用法:

在实现动画的过程中,可能会需要使用一种常用的方式:overflow障眼法。

用于实现一些类似Tab切换的效果:

html代码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      .wrapper {
        width: 100px;
        height: 100px;
        overflow: hidden;
      }
      #tabs {
        display: flex;
        width: 200px;
        height: 100px;
        transition: transform 0.3s;
      }
      .tab-pane-1 {
        width: 100px;
        height: 100px;
        line-height: 100px;
        text-align: center;
        background: red;
      }
      .tab-pane-2 {
        width: 100px;
        height: 100px;
        line-height: 100px;
        text-align: center;
        background: yellow;
      }
      .transform {
        transform: translateX(-50%);
      }
    </style>
  </head>
  <body>
    <div>
      <div id="tabs">
        <div>1</div>
        <div>2</div>
      </div>
    </div>
    <button onclick="switchTabPane()">切换Tab</button>

    <script>
      function switchTabPane() {
        var el = document.getElementById(&#39;tabs&#39;)
        el.className = el.className ? &#39;&#39; : &#39;transform&#39;
      }
    </script>
  </body>
</html>

动画效果点击此处查看https://codepen.io/wjq990112/pen/MWwrXWo

实现这个效果只需要将容器设置为overflow: hidden;,然后对容器内的tab侦听transform属性,使用transform: translateX()使其在 X轴方向移动,大功告成了。

还有一些旋转效果也可以使用transform: rotateZ();使其在浏览器平面上旋转实现,默认是以几何中心为中心点进行旋转。

animation & keyframes

animation属性的用法和transition比较相似,接下来由我来详细介绍一下。

animation CSS 属性是 animation-name,animation-duration,animation-timing-function,animation-delay,animation-iteration-count,animation-direction,animation-fill-mode 和 animation-play-state 属性的一个简写属性形式。

先做个简单的旋转效果体验一下:

html代码

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      @keyframes rotate {
        0% {
          transform: rotateZ(0deg);
        }
        100% {
          transform: rotateZ(359deg);
        }
      }
      .rotate {
        width: 100px;
        height: 100px;
        line-height: 100px;
        text-align: center;
        color: #fff;
        background: red;
        /* 为元素设定 10s 的旋转动画 */
        animation: rotate 10s linear infinite;
      }
      .wrapper {
        display: flex;
        width: 200px;
        height: 200px;
        justify-content: center;
        align-items: center;
      }
    </style>
  </head>
  <body>
    <div>
      <div>旋转</div>
    </div>
  </body>
</html>

动画效果点击此处查看https://codepen.io/wjq990112/pen/mdJXeqm

这是一个基础的旋转动画,用到了animationkeyframes两个常用于制作动画的 CSS 属性。

animation

现在我们来讲一下基础用法:

css代码

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

这样讲肯定还是不懂,继续一条一条拆解开给大家讲解:

css代码

animation-name: rotate; /* 自定义 keyframes 名 */
animation-duration: 10s; /* 设定单次过渡动画时长 */
animation-timing-function: linear; /* 设定单次过渡动画效果 */
animation-delay: 0s; /* 设定单次过渡动画延迟时间 */
animation-iteration-count: infinite; /* 设定过渡动画执行次数 infinite 表示无限循环 */
animation-direction: normal; /* 设定过渡动画方向 可对奇数偶数次动画分别设定 */
animation-fill-mode: none; /* 设定过渡动画的填充模式 */
animation-play-state: running; /* 设定过渡动画运行或停止 */

相信大部分属性都很好理解,只有两个属性可能会比较难理解。

animation-directionanimation-fill-mode应该可以说是最难理解的两个属性了,我们再详细讲解一下:

css代码

/*
 *	normal: 按照 keyframes 设定的动画方向运行
 *	reverse: 按照 keyframes 设定的动画方向的反方向运行
 *	alternate: 先按照 keyframes 设定的动画方向运行 运行结束后再反方向运行
 *	alternate-reverse: 先按照 keyframes 设定的动画方向的反方向运行 运行结束后再正向运行
 */
animation-direction: normal | reverse | alternate | alternate-reverse;
/*
 *	none: 不设定填充模式 默认在动画开始及结束时都停留在动画未开始的状态
 *	forwards: 动画结束后停留在动画的最后一帧
 *	backwards: 动画开始前停留在动画的第一帧
 *	both: 动画开始前和动画结束后分别停留在动画的第一帧和最后一帧
 */
animation-fill-mode: none | forwards | backwards | both;

这两个属性可以说是最难理解的,如果想看设定之后的效果,可以转战MDN

transition CSS property 전환 속성, 전환 기간, 전환 타이밍 기능 및 전환 지연에 대한 약식 속성입니다. ——MDN

html 코드에서 인용

@keyframes rotate {
  0% {
    transform: rotateZ(0deg);
  }
  100% {
    transform: rotateZ(359deg);
  }
}

애니메이션 효과 주소를 보려면 여기를 클릭하세요 https://codepen.io/wjq990112/pen/PoqEemX

경험한 후 이제 사용법 자세히 :🎜🎜css code🎜
/*
 *	①
 */
@keyframes move {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(200px);
  }
  100% {
    transform: translateX(0);
  }
}
.move {
  width: 100px;
  height: 50px;
  background: yellow;
  animation: move 1s linear infinite;
}
/*
 *  ②
 */
@keyframes move {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(200px);
  }
}
.move {
  width: 100px;
  height: 50px;
  background: yellow;
  animation: move 0.5s linear infinite alternate;
}
🎜이렇게 쓰면 이해가 안 되실 수도 있습니다. 하나씩 풀어보겠습니다:🎜🎜css code
🎜rrreee🎜 전환 속성은 위 4가지 항목과 CSS 속성의 조합으로 구성됩니다. 🎜🎜첫 번째와 두 번째 속성은 필수이며 전환 애니메이션을 추가하고 애니메이션 지속 시간을 지정하는 데 필요한 청취 속성을 지정하는 데 사용됩니다. 🎜🎜세 번째 및 네 번째 속성은 선택 사항이며 전환 애니메이션의 효과 및 지연을 설정하는 데 사용됩니다. 🎜🎜🎜transition-timing-function의 선택적 값은 🎜🎜https://developer.mozilla.org/zh-CN/docs/Web/CSS/transition-timing-function🎜🎜🎜에 자세히 설명되어 있습니다. 첫 번째 속성은 2개의 특수 값이기도 합니다. 없음: 어떤 속성도 듣지 않습니다. all: 모든 속성을 듣고 전환 애니메이션을 추가합니다. 🎜🎜세 번째 속성이 생략되면 두 번째 항목이 자동으로 애니메이션 효과 지연으로 구문 분석됩니다. 🎜🎜아직 이해하기 어렵습니다. 예를 들어 보겠습니다. 🎜🎜css code🎜🎜🎜transition: background 1seasy-in-out 0.2s;
🎜🎜🎜위의 예는 이전 코드 부분. 🎜🎜백그라운드의 변경 사항을 듣고 1초 전환 애니메이션을 추가한다는 의미입니다. 전환 애니메이션의 효과는 천천히 시작하고 천천히 끝나는 것이며, 실행이 시작될 때까지는 실행되지 않습니다. 0.2초 동안 속성이 변경됩니다. 🎜🎜그런 다음 위 코드의 이 섹션: 🎜🎜css code🎜rrreee🎜코드의 transition 속성은 전환 애니메이션을 background``color``width 에 추가합니다. class=box 태그의 세 가지 속성이 변경되면 기본 또는 지정된 애니메이션 효과가 자동으로 추가됩니다. 🎜🎜다음으로 고급 용도로 사용하겠습니다. 🎜🎜애니메이션을 구현하는 과정에서 일반적인 방법인 overflow 블라인드 방법을 사용해야 할 수도 있습니다. 🎜🎜 전환과 유사한 효과를 얻는 데 사용됩니다. 🎜🎜html code🎜rrreee🎜🎜애니메이션 효과를 보려면 여기를 클릭하세요. https://codepen.io/wjq990112/pen/MWwrXWo🎜🎜🎜 구현 이 효과를 얻으려면 컨테이너를 overflow:hidden;으로 설정한 다음 transform 속성을 ​​수신하기만 하면 됩니다. 컨테이너를 삭제하고 transform:transformX()를 사용하여 X축 방향으로 이동하면 작업이 완료됩니다. 🎜🎜브라우저 평면에서 회전하기 위해 transform:rotateZ();를 사용하여 실현할 수 있는 몇 가지 회전 효과도 있습니다. 기본값은 기하학적 중심을 중심점으로 회전하는 것입니다. 🎜🎜animation & keyframes🎜🎜 animation 속성의 사용법은 transition과 유사합니다. 🎜🎜🎜애니메이션 CSS 속성은 animation-name, animation-duration, animation-timing-function, animation-delay, animation-iteration-count, animation-direction, animation-fill-mode 및 animation-play-의 약어입니다. 상태 속성 속성 형태. 🎜🎜🎜먼저 경험해 볼 수 있는 간단한 회전 효과 만들기: 🎜🎜html 코드
🎜rrreee🎜🎜애니메이션 효과를 보려면 여기를 클릭하세요 https://codepen.io/wjq990112/pen/mdJXeqm🎜🎜🎜이것은 기본입니다 회전 애니메이션은 애니메이션을 만드는 데 일반적으로 사용되는 두 가지 CSS 속성인 animationkeyframes을 사용합니다. ㅋㅋㅋ CSS code🎜rrreee🎜저는 대부분의 속성을 믿습니다. 모두 이해하기 쉽지만, 더 이해하기 어려울 수 있는 속성은 두 가지뿐입니다. 🎜🎜animation-directionanimation-fill-mode는 가장 이해하기 어려운 두 가지 속성이라고 할 수 있습니다. 자세히 설명하겠습니다. 🎜🎜css code🎜rrreee 🎜이 두 가지 속성은 가장 이해하기 어렵다고 할 수 있습니다. 설정 후 효과를 보려면 MDN으로 전환하면 됩니다. 🎜🎜🎜keyframes🎜🎜🎜이 CSS 속성은 간단한 애니메이션 제작을 배운 학생들이 반드시 이해해야 한다고 믿습니다. 매우 간단하며 키프레임입니다. 🎜🎜애니메이션의 키프레임을 설정하면 CSS가 모션 경로를 자동으로 채웁니다. 🎜🎜css 코드🎜
@keyframes rotate {
  0% {
    transform: rotateZ(0deg);
  }
  100% {
    transform: rotateZ(359deg);
  }
}

上面这段代码,就是为设定了animation属性的div标签创建了两个关键帧,一个是动画起始位置的样式,另一个是动画结束位置的样式,CSS将自动填充动画的过程(即旋转 359 度)。

不仅仅可以设置开始和结束的位置(0%可以使用from关键字代替,100%可以使用to关键字代替),还可以在动画的运行过程中插入关键帧,例如33%50%66%等等,CSS会按照关键帧的样式,对动画进行自动填充。

通常情况下,keyframes会与animation配合使用。

讲完了animationkeyframes的用法,我们来看一道面试题,来自本人 2020 年某跳动实习生招聘一面:

请你使用 CSS 实现一个方块来回移动,无限循环。

这个题目其实有 2 种做法,但是原理都是一样的,这里就不放 HTML 代码了,直接放 CSS 的部分:

/*
 *	①
 */
@keyframes move {
  0% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(200px);
  }
  100% {
    transform: translateX(0);
  }
}
.move {
  width: 100px;
  height: 50px;
  background: yellow;
  animation: move 1s linear infinite;
}
/*
 *  ②
 */
@keyframes move {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(200px);
  }
}
.move {
  width: 100px;
  height: 50px;
  background: yellow;
  animation: move 0.5s linear infinite alternate;
}

推荐学习:CSS视频教程

위 내용은 CSS로 애니메이션을 만드는 일반적인 기술을 설명하는 문서(컬렉션)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 掘金에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
두 개의 이미지와 API : 제품을 다시 칠하는 데 필요한 모든 것두 개의 이미지와 API : 제품을 다시 칠하는 데 필요한 모든 것Apr 15, 2025 am 11:27 AM

최근에 제품 이미지의 색상을 동적으로 업데이트하는 솔루션을 찾았습니다. 따라서 제품 중 하나만 사용하여 다른 방식으로 색칠 할 수 있습니다.

주간 플랫폼 뉴스 : 제 3 자 코드, 수동 혼합 콘텐츠, 가장 느린 연결이있는 국가의 영향주간 플랫폼 뉴스 : 제 3 자 코드, 수동 혼합 콘텐츠, 가장 느린 연결이있는 국가의 영향Apr 15, 2025 am 11:19 AM

이번 주에 라운드 업, Lighthouse는 타사 스크립트에 빛을 비추고 불안한 자원이 안전한 사이트에서 차단되고 많은 국가 연결 속도가 차단됩니다.

직접 비자 스크립트 기반 분석을 호스팅하는 옵션직접 비자 스크립트 기반 분석을 호스팅하는 옵션Apr 15, 2025 am 11:09 AM

사이트에서 방문자 및 사용 데이터를 추적하는 데 도움이되는 분석 플랫폼이 많이 있습니다. 아마도 널리 사용되는 Google 웹 로그 분석

그것은 모두 헤드에있는 모든 것 : React Helmet과 함께 React 전원 사이트의 문서 헤드 관리그것은 모두 헤드에있는 모든 것 : React Helmet과 함께 React 전원 사이트의 문서 헤드 관리Apr 15, 2025 am 11:01 AM

문서 헤드는 웹 사이트에서 가장 화려한 부분이 아닐 수도 있지만 웹 사이트의 성공에 중요합니다.

JavaScript의 Super () 란 무엇입니까?JavaScript의 Super () 란 무엇입니까?Apr 15, 2025 am 10:59 AM

Super ()?를 호출하는 JavaScript를 볼 때 어떤 일이 발생 하는가. 아동 클래스에서는 Super ()를 사용하여 부모의 생성자와 Super를 호출합니다. 그것의 접근

다양한 유형의 기본 JavaScript 팝업 비교다양한 유형의 기본 JavaScript 팝업 비교Apr 15, 2025 am 10:48 AM

JavaScript에는 사용자 상호 작용을위한 특수 UI를 표시하는 다양한 내장 팝업 API가 있습니다. 뛰어나게:

액세스 가능한 웹 사이트를 구축하기가 어려운 이유는 무엇입니까?액세스 가능한 웹 사이트를 구축하기가 어려운 이유는 무엇입니까?Apr 15, 2025 am 10:45 AM

나는 다른 날에 많은 회사들이 액세스 가능한 웹 사이트를 만드는 데 어려움을 겪고있는 이유에 대해 다른 프론트 엔드 사람들과 대화를 나누고있었습니다. 액세스 가능한 웹 사이트가 왜 그렇게 어려운가

'숨겨진'속성은 눈에 띄게 약합니다'숨겨진'속성은 눈에 띄게 약합니다Apr 15, 2025 am 10:43 AM

당신이해야 할 일을 정확하게 수행하는 HTML 속성이 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.