---
id: 587d78a7367417b2b2512ae1
title: Create Movement Using CSS Animation
challengeType: 0
videoUrl: 'https://scrimba.com/c/c7amZfW'
forumTopicId: 301051
localeTitle: 使用 CSS 动画创建运动
---
## Description
当元素的 position 被指定,如 fixed 或者 relative 时,CSS 偏移属性 right、left、top 和 bottom可以用在动画规则里创建动作。
就像下面的例子展示的那样,你可以在 50%keyframe 处设置 top 属性为 50px, 在开始(0%)和最后(100%)keframe 处设置为 0px,以产生项目向下运动,然后返回的动作效果。
```css
@keyframes rainbow {
0% {
background-color: blue;
top: 0px;
}
50% {
background-color: green;
top: 50px;
}
100% {
background-color: yellow;
top: 0px;
}
}
```
## Instructions
让 div 水平运动。使用 left 偏移属性,添加 @keyframes 规则,让 rainbow 在 0% 的 0 像素开始,在 50% 时移动到 25 像素,在 100% 时时移动到 -25 像素。不要替换编辑器里的 top 属性,动画应该同时向水平和竖直方向运动。
## Tests
```yml
tests:
- text: '0% 的 @keyframes 规则应该为向 left 偏移 0px。'
testString: assert(code.match(/0%\s*?{\s*?background-color:\s*?blue;\s*?top:\s*?0(px)?;\s*?left:\s*?0(px)?;\s*?}/gi));
- text: '50% 的 @keyframes 规则应该为向 left 偏移25px。'
testString: assert(code.match(/50%\s*?{\s*?background-color:\s*?green;\s*?top:\s*?50px;\s*?left:\s*?25px;\s*?}/gi));
- text: '100% 的 @keyframes 规则应该为向 left 偏移-25px。'
testString: assert(code.match(/100%\s*?{\s*?background-color:\s*?yellow;\s*?top:\s*?0(px)?;\s*?left:\s*?-25px;\s*?}/gi));
```
## Challenge Seed
## Solution
```html
// solution required
```