freeCodeCamp/curriculum/challenges/chinese/01-responsive-web-design/applied-visual-design/change-animation-timing-wit...

43 lines
1.7 KiB
Markdown
Raw Normal View History

---
id: 587d78a8367417b2b2512ae7
title: 使用关键字更改动画定时器
challengeType: 0
videoUrl: 'https://scrimba.com/c/cJKvwCM'
forumTopicId: 301045
---
# --description--
在 CSS 动画里,`animation-timing-function` 规定动画的速度曲线。速度曲线定义动画从一套 CSS 样式变为另一套所用的时间。如果要描述的动画是一辆车在指定时间内(`animation-duration`)从 A 运动到 B那么 `animation-timing-function` 表述的就是车在运动中的加速和减速等过程。
已经有了很多预定义的值可以直接使用于大部分场景。比如,默认的值是 `ease`,动画以低速开始,然后加快,在结束前变慢。其它常用的值包括 `ease-out`,动画以高速开始,以低速结束;`ease-in`,动画以低速开始,以高速结束;`linear`,动画从头到尾的速度是相同的。
# --instructions--
给 id 为 `ball1``ball2` 的元素添加 `animation-timing-function``ball1` 赋值为 `linear``ball2` 赋值为 `ease-out`。它们的 `animation-duration` 都为 2 秒,注意观察它们在开始和结束时的不同。
# --hints--
id 为 `ball1` 的元素的 `animation-timing-function` 属性值应该为 linear。
```js
const ball1Animation = $('#ball1')
.css('animation-timing-function')
.replace(/\s/g, '');
assert(ball1Animation == 'linear' || ball1Animation == 'cubic-bezier(0,0,1,1)');
```
id 为 `ball2` 的元素的 `animation-timing-function` 属性值应该为 ease-out。
```js
const ball2Animation = $('#ball2')
.css('animation-timing-function')
.replace(/\s/g, '');
assert(
ball2Animation == 'ease-out' || ball2Animation == 'cubic-bezier(0,0,0.58,1)'
);
```
# --solutions--