css 动画
写法
@keyframes 动画名称 {
0% {
}
100% {
background-position: -1600px 0;
}
}
@keyframes 动画名称 {
from {
background-color:red;
}
to {
background-color:blue;
}
}
属性
关于animation-timing-function
| |
---|
linear | 动画从头到尾的速度是相同的。 |
ease | 默认。动画以低速开始,然后加快,在结束前变慢。 |
ease-in | 动画以低速开始。 |
ease-out | 动画以低速结束。 |
ease-in-out | 动画以低速开始和结束。 |
steps(int,start|end) | 指定了时间函数中的间隔数量(步长)。有两个参数,第一个参数指定函数的间隔数,该参数是一个正整数(大于 0)。 第二个参数是可选的,表示动画是从时间段的开头连续还是末尾连续。含义分别如下:start:表示直接开始。end:默认值,表示戛然而止。 |
动画案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.move {
width: 100px;
height: 100px;
background-color: burlywood;
border-radius: 50px;
animation-name: move;
animation-duration: 3s;
animation-timing-function: ease;
animation-delay: 1s;
animation-fill-mode: forwards;
animation-iteration-count: infinite;
animation-direction: alternate;
}
.move:hover {
animation-play-state: paused
}
@keyframes move {
25% {
transform: translate(400px,0);
}
50% {
transform: translate(400px,400px);
}
75% {
transform: translate(0,400px);
}
100% {
transform: translate(0,0);
}
}
</style>
</head>
<body>
<div class="move">
</div>
</body>
</html>
动画的综合写法
animation: name duration timing-function delay iteration-count direction fill-mode;
animation-play-state: paused;
注意animation-play-state: paused;没有在默认中;