CSS3——@keyframe动画的基本用法

-
-
2024-03-24

CSS3——@keyframe动画的基本用法,常见错误及解决方案

基本介绍

1:简介

CSS动画可以为网站添加生动的交互效果。在CSS3中,@keyframes规则被引入,用于定义CSS动画的关键帧和属性值。@keyframes规则提供了一个非常强大和灵活的工具,允许开发人员控制动画的细节,以创建各种类型的动画效果。在本文中,我们将深入探讨@keyframes规则,了解如何使用它来创建各种类型的动画。

2:什么是@keyframes规则

在CSS中,@keyframes规则用于定义动画的关键帧和属性值。关键帧是指动画中的重要时间点,定义了元素的状态,以及该状态应该持续多长时间。在@keyframes规则中,您可以定义任意数量的关键帧,每个关键帧都可以设置任意数量的CSS属性。

@keyframes规则是一种CSS规则,可以使用它定义动画,并将动画应用于HTML元素。与其他CSS规则一样,@keyframes规则也遵循CSS的层叠性和继承性。这意味着您可以在CSS代码中使用多个@keyframes规则,并将它们与其他CSS规则结合使用,以创建复杂的动画效果。

3:如何使用@keyframes规则

要创建动画,您需要使用两个关键字:@keyframes和animation。@keyframes用于定义动画的关键帧和属性值,而animation用于将动画应用于HTML元素。

动画创建@keyframes

@keyframes 通过在动画序列中定义关键帧的样式,来控制CSS动画序列中的步骤。

使用 @keyframes 可以创建动画。
在动画过程中,您可以更改CSS样式的设定多次。
指定的变化时发生时使用%,或关键字“from”和“to”,等价于0%到100%
0%是开头动画,100%是当动画完成。

 @keyframes mycolor {
    0% { background-color: red; }
    30% { background-color: darkblue; }
    50% { background-color: yellow; }
    70% { background-color: darkblue; }
    100% { background-color: red; }
  }

动画应用animation

使用animation属性, 当将动画绑定到某个选择器上时才会产生动画效果

animation属性如下:

1) animation-name:动画名称 指定了一个 @keyframes 动画,指定要使用哪一个关键帧。

2) animation-duration:动画持续时间 定义动画完成一个周期需要多少秒或毫秒。

3) animation-timing-function:动画的运动方式 指定动画将如何完成一个周期

  ease;默认-渐进
  ease-in;  
  ease-out;
  ease-in-out;
  linear;#线性变化
  steps(数值, 定位) 定位:start/end 默认end指逐步运动

4) animation-delay:动画的延迟时间 动画什么时候开始。
        5) animation-iteration-count:动画循环次数 动画应该播放多少次,默认1
其值为:n(一个数字,指定播放多少次)、infinite(指定播放无限次)、

6)animation-fill-mode:结束状态 设置动画结束时盒子的状态

  forwards 保持动画结束后的状态
  backwards 动画结束后回到最初的状态

7) animation-direction:动画的执行顺序 动画是否应该播放完后逆向交替循环(对设置了多次播放的动画有效)
其值为:normal(默认值,动画正常)、reverse 反向、alternate(动画交替循环逆向运动)

8) 简写方式
animation: 动画执行时间 延迟时间 执行关键帧名称 运动方式 运动次数 结束状态 动画执行顺序;

最简方式
animation: 动画执行时间 执行关键帧名称; 执行时间和延迟时间顺序不可调整

 

4:示例

示例一:播放两次时长为5s的变色(红->黄->绿->h红)动画,结束。

<!DOCTYPE html>
<html>
<head>
<meta charset = "utf-8">
<style>
div { 
	width: 200px;
	height: 200px;
	background: red;
}
@keyframes mycolor {
	0% { background-color: red; }
	30% { background-color: yellow; }
	60% { background-color: green; }
	100% { background-color: red; }
}
div:hover {
	animation-name: mycolor;
	animation-duration: 5s;
	animation-timing-function: linear;
	animation-iteration-count: 2;
}
</style>
</head>
<body>
 	<div></div>
</body>
</html>

示例二:使用简写方式

@keyframes myAnimation {
 from { background-color: red; }
 to { background-color: yellow; }
}
.element {
 animation: myAnimation 2s linear infinite;
}

二、常见错误及解决方案

1: @keyframes 不能实现突变的状态变化

@keyframes原理把样式的从一个状态,慢慢转变为另一个状态。

所以,如果不存在渐变的状态,是无法用@keyframes构成动画的,例如:

div {
    animation: appear 2s;
}
@keyframes appear {
    from { display:none; }
    to   { display:block;}
}

display:none;是将div消失并且不占空间,display:block;则是将div展现存在并占据空间。
但是 display:none;和display:block;是突变的 ,所以@keyframes无法实现。

同理其他种类的突变属性也无法拥有@keyframes的动画效果,@keyframes 只存在于渐变属性当中,例如各种width, height, opacity等属性值为数值的属性。

display替代方案

1.占据空间:visiblity
@keyframes appear {
	100% { 
		opacity: 1;
		visibility: visible;
	}
	100% { 
		opacity: 0;
		visibility: hidden;
	}
}
2.不想占据空间:绝对定位+visiblity

使用绝对定位使元素脱离文档流,搭配z-index控制层叠关系使它出现或者消失。

//自身css效果
.animate {
    position: absolute;
    top: 0;
    left: 0;
    transition: 1s;
    opacity: 0;
    visibility: hidden;
    z-index: 0;
}

//出现时的效果
.cur {
    opacity: 1;
    visibility: visible;
    z-index: 10;
}
3.消失前占据空间但是消失后不占据空间:timeout和visiblity

2: @keyframes会增添/覆盖属性

/*
* div 在2s内下移200px
*/
div {
    position:absolute;
    top:0px;
    animation: move 2s;
}
@keyframes move {
    from { top:20px; }
    to   { top:200px;}
}

此例中,div初始状态是top:0;
@keyframes首先用top:20px覆盖原属性(top:0;),然后再启动@keyframes功能。

结果:div突然瞬间下降20px,然后在2秒内下降至指定位置(top:200px;)

“您的支持是我持续分享的动力”

微信收款码
微信
支付宝收款码
支付宝

目录