Part 3 일반적인 CSS 스타일(3) 이 블로그 게시물에서는 이미 CSS의 애니메이션 효과를 사용한 전환 및 변형을 소개했습니다. 오늘은 CSS의 애니메이션에 대해 이야기해 보겠습니다. 애니메이션을 추가하면 애니메이션 효과가 더욱 낙관적으로 변합니다.
애니메이션
애니메이션 구현은 키프레임을 통해 구현해야 합니다. 플래시의 키프레임과 유사한 키프레임(키프레임). 키프레임에는 고유한 구문 규칙이 있습니다. 이름은 "@keyframes"로 시작하고 그 뒤에 "애니메이션 이름"과 중괄호 쌍 "{}"이 옵니다. 우리의 CSS 스타일 작성 방법과 비슷합니다. "0%"와 "100%" 사이와 같이 여러 백분율로 구성된 "@keyframes"의 스타일 규칙의 경우 이 규칙에서 여러 백분율을 생성할 수 있으며 각 백분율에 애니메이션 효과가 필요한 요소를 제공합니다. 다양한 속성을 추가하여 요소가 이동, 요소의 색상, 위치, 크기, 모양 등과 같은 지속적으로 변화하는 효과를 얻을 수 있도록 합니다. 그러나 한 가지 주목할 점은 "fromt"와 "to"를 사용하여 애니메이션이 시작되고 끝나는 위치를 나타낼 수 있다는 것입니다. 즉, "from"은 "0%"와 동일하고 "to"는 "100"과 동일합니다. %", "0%"는 다른 속성 값과 마찬가지로 백분율 기호를 생략할 수 없다는 점을 언급할 가치가 있습니다. 여기에 백분율 기호("%")를 추가해야 합니다. 그렇지 않은 경우 이 키프레임은 유효하지 않으며 아무런 효과도 없습니다. 키프레임 단위는 백분율 값만 허용하기 때문입니다.
다양한 브라우저에서 쓰기:
内核类型 | 写法 |
---|---|
Webkit(Chrome/Safari) | -webkit-animation |
Gecko(Firefox) | -moz-animation |
Presto(Opera) | |
Trident(IE) | -ms-animation |
W3C | animation |
속성 설명:
1. animation-name: 객체에 적용된 애니메이션 이름을 검색하거나 설정합니다. @keyframes 규칙과 함께 사용해야 합니다. 애니메이션 이름은 자유롭게 선택할 수 있으며 의미가 더 좋습니다
2. animation-duration: 객체 애니메이션의 지속 시간을 검색하거나 설정합니다.
3. animation-timing-function: 객체 애니메이션의 전환 유형을 검색하거나 설정합니다.
값:
선형: 선형 전환. 베지어 곡선과 동일(0.0, 0.0, 1.0, 1.0)
편함: 부드러운 전환. 베지어 곡선과 동일(0.25, 0.1, 0.25, 1.0)
ease-in: 느린 속도에서 빠른 속도로. 베지어 곡선과 동일(0.42, 0, 1.0, 1.0)
ease-out: 빠른 것에서 느린 것까지. 베지어 곡선과 동일(0, 0, 0.58, 1.0)
ease-in-out: 느린 속도에서 빠른 속도로, 그리고 다시 느린 속도로. 베지어 곡선과 동일(0.42, 0, 0.58, 1.0)
Cubic-bezier(
4. animation-iteration-count: 객체 애니메이션의 주기 수를 검색하거나 설정합니다.
값:
무한 : 무한 루프
number: 지정된 개체 애니메이션의 특정 주기 수
5. animation-direction: 객체 애니메이션이 루프에서 반대 방향으로 움직이는지 검색하거나 설정합니다.
값:
법선: 법선 방향
대체: 정방향 및 역방향 교대로
6. animation-play-state: 객체 애니메이션의 상태를 검색하거나 설정합니다
달리기:스포츠
일시 중지됨: 일시 중지됨
7. animation-fill-mode: 객체 애니메이션 시간 이외의 상태를 검색하거나 설정합니다.
값:
없음: 기본값입니다. 객체 애니메이션 이외의 상태를 설정하지 마세요
전달: 객체 상태를 애니메이션 종료 시 상태로 설정
거꾸로: 객체 상태를 애니메이션이 시작될 때의 상태로 설정
둘 다: 객체 상태를 애니메이션의 끝 또는 시작 상태로 설정
다음은 종합적인 설명을 위한 예시입니다.
CSS 코드:
<span style="font-family: 'Microsoft YaHei'; font-size: 15px;"><span style="color: #800000;"> #animation </span>{<span style="color: #ff0000;"> width</span>:<span style="color: #0000ff;"> 250px</span>;<span style="color: #ff0000;"> height</span>:<span style="color: #0000ff;"> 250px</span>;<span style="color: #ff0000;"> background-color</span>:<span style="color: #0000ff;"> brown</span>;<span style="color: #ff0000;"> opacity</span>:<span style="color: #0000ff;"> 0.5</span>;<span style="color: #ff0000;"> position</span>:<span style="color: #0000ff;">absolute</span>;<span style="color: #ff0000;"> left</span>:<span style="color: #0000ff;">40%</span>;<span style="color: #ff0000;"> overflow</span>:<span style="color: #0000ff;"> hidden</span>; }<span style="color: #800000;"> #animation span </span>{<span style="color: #ff0000;"> font-family</span>:<span style="color: #0000ff;"> "微软雅黑"</span>;<span style="color: #ff0000;"> font-size</span>:<span style="color: #0000ff;"> 20px</span>;<span style="color: #ff0000;"> color</span>:<span style="color: #0000ff;"> #ccc</span>;<span style="color: #ff0000;"> opacity</span>:<span style="color: #0000ff;"> 0</span>;<span style="color: #ff0000;"> display</span>:<span style="color: #0000ff;"> block</span>;<span style="color: #ff0000;"> margin</span>:<span style="color: #0000ff;"> 30px</span>; }<span style="color: #800000;"> #text1:hover </span>{<span style="color: #ff0000;"> -moz-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;/*鼠标经过时暂停动画*/<span style="color: #ff0000;"> -webkit-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> -o-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> -ms-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> animation-play-state</span>:<span style="color: #0000ff;">paused</span>; }<span style="color: #800000;"> #text2:hover </span>{<span style="color: #ff0000;"> -moz-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> -webkit-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> -o-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> -ms-animation-play-state</span>:<span style="color: #0000ff;">paused</span>;<span style="color: #ff0000;"> animation-play-state</span>:<span style="color: #0000ff;">paused</span>; }<span style="color: #800000;"> #text1 </span>{<span style="color: #ff0000;"> -webkit-animation-name</span>:<span style="color: #0000ff;">animation1</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">动画名称</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-duration</span>:<span style="color: #0000ff;">4s</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">动画持续时间</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-timing-function</span>:<span style="color: #0000ff;">ease-in</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">变化由慢到快</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">过了2S后开始动画</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">设置动画无限播放</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-transform</span>:<span style="color: #0000ff;"> translate(55px)</span>;<span style="color: #ff0000;"> animation-name</span>:<span style="color: #0000ff;">animation1</span>;<span style="color: #ff0000;"> animation-delay</span>:<span style="color: #0000ff;"> 4s</span>;<span style="color: #ff0000;"> animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> transform</span>:<span style="color: #0000ff;"> translate(55px)</span>;<span style="color: #ff0000;"> -ms-animation-name</span>:<span style="color: #0000ff;">animation1</span>;<span style="color: #ff0000;"> -ms-animation-duration</span>:<span style="color: #0000ff;">4s </span>;<span style="color: #ff0000;"> -ms-animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> -ms-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> -ms-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> -ms-transform</span>:<span style="color: #0000ff;"> translate(55px)</span>;<span style="color: #ff0000;"> -moz-animation-name</span>:<span style="color: #0000ff;">animation1</span>;<span style="color: #ff0000;"> -moz-animation-delay</span>:<span style="color: #0000ff;">4s </span>;<span style="color: #ff0000;"> -moz-animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> -moz-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> -moz-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> -moz-transform</span>:<span style="color: #0000ff;"> translate(55px)</span>; }<span style="color: #800000;"> #text2 </span>{<span style="color: #ff0000;"> -webkit-animation-name</span>:<span style="color: #0000ff;">animation2</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">动画名称</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-duration</span>:<span style="color: #0000ff;">4s</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">动画持续时间</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-timing-function</span>:<span style="color: #0000ff;">ease-in</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">变化由慢到快</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">过了2S后开始动画</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #008000;">/*</span><span style="color: #008000;">设置动画无限播放</span><span style="color: #008000;">*/</span><span style="color: #ff0000;"> -webkit-transform</span>:<span style="color: #0000ff;"> translate(60px)</span>;<span style="color: #ff0000;"> animation-name</span>:<span style="color: #0000ff;">animation2</span>;<span style="color: #ff0000;"> animation-delay</span>:<span style="color: #0000ff;"> 4s</span>;<span style="color: #ff0000;"> animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> transform</span>:<span style="color: #0000ff;"> translate(60px)</span>;<span style="color: #ff0000;"> -ms-animation-name</span>:<span style="color: #0000ff;">animation2</span>;<span style="color: #ff0000;"> -ms-animation-duration</span>:<span style="color: #0000ff;">4s </span>;<span style="color: #ff0000;"> -ms-animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> -ms-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> -ms-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> -ms-transform</span>:<span style="color: #0000ff;"> translate(60px)</span>;<span style="color: #ff0000;"> -moz-animation-name</span>:<span style="color: #0000ff;">animation2</span>;<span style="color: #ff0000;"> -moz-animation-delay</span>:<span style="color: #0000ff;">4s </span>;<span style="color: #ff0000;"> -moz-animation-timing-function</span>:<span style="color: #0000ff;"> ease-in</span>;<span style="color: #ff0000;"> -moz-animation-delay</span>:<span style="color: #0000ff;"> 2s</span>;<span style="color: #ff0000;"> -moz-animation-iteration-count</span>:<span style="color: #0000ff;"> infinite</span>;<span style="color: #ff0000;"> -moz-transform</span>:<span style="color: #0000ff;"> translate(60px)</span>; }<span style="color: #800000;"> @-webkit-keyframes animation1 </span>{<span style="color: #ff0000;"> 0%{-webkit-transform</span>:<span style="color: #0000ff;"> translate(-10px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 0</span>;}<span style="color: #800000;"> 20%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(25px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 0.5</span>;}<span style="color: #800000;"> 45%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(45px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 1</span>;}<span style="color: #800000;"> 100%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(60px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 0.8</span>;}<span style="color: #800000;"> } @-webkit-keyframes animation2 </span>{<span style="color: #ff0000;"> 0%{-webkit-transform</span>:<span style="color: #0000ff;"> translate(280px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 0</span>;}<span style="color: #800000;"> 30%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(200px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 0.5</span>;}<span style="color: #800000;"> 65%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(130px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;"> 1</span>;}<span style="color: #800000;"> 100%</span>{<span style="color: #ff0000;">-webkit-transform</span>:<span style="color: #0000ff;"> translate(60px)</span>;<span style="color: #ff0000;">opacity</span>:<span style="color: #0000ff;">0.8</span>;}<span style="color: #800000;"> }</span></span>
HTML代码:
<span style="font-family: 'Microsoft YaHei'; font-size: 16px;"><span style="color: #000000;"><div id="animation"> </span><span style="color: #0000ff;"><</span><span style="color: #800000;">span </span><span style="color: #ff0000;">id</span><span style="color: #0000ff;">="text1"</span><span style="color: #0000ff;">></span>这是ly婠婠的博客<span style="color: #0000ff;"></</span><span style="color: #800000;">span</span><span style="color: #0000ff;">></span> <span style="color: #0000ff;"><</span><span style="color: #800000;">span </span><span style="color: #ff0000;">id</span><span style="color: #0000ff;">="text2"</span><span style="color: #0000ff;">></span>欢迎访问和评论!<span style="color: #0000ff;"></</span><span style="color: #800000;">span</span><span style="color: #0000ff;">></span> <span style="color: #0000ff;"></</span><span style="color: #800000;">div</span><span style="color: #0000ff;">></span></span>
效果如下:
解析说明:
在这个例子中,效果如上图。这里主要是利用animation和translate来达到一个文字渐进的效果。translate的作用是让文字根据给定值发生平移。animation则利用关键帧和百分比数值来将平移过程细分成几个帧,然后设置持续时间,一帧帧连接起来形成动画。