freeCodeCamp/curriculum/challenges/chinese/01-responsive-web-design/applied-visual-design/create-movement-using-css-a...

2.8 KiB
Raw Blame History

id title challengeType videoUrl forumTopicId dashedName
587d78a7367417b2b2512ae1 使用 CSS 动画创建动画 0 https://scrimba.com/c/c7amZfW 301051 create-movement-using-css-animation

--description--

在元素的 position 已有指定值(如 fixed 或者 relativeCSS 偏移属性 rightlefttopbottom 可以用在动画规则里创建动作。

就像下面的例子展示的那样,你可以在 50% keyframe 处设置 top 属性为 50px在开始0%和最后100%keyframe 处设置为 0px以实现元素先向下运动然后返回的动作效果。

@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%keyframe 下从偏移 0 像素开始;在 50% 时偏移 25 像素;在 100% 时偏移 -25 像素。不要修改编辑器里的 top 属性,元素应该同时在水平和竖直方向运动。

--hints--

0%@keyframes 规则应为向 left 偏移 0px

assert(
  code.match(
    /0%\s*?{\s*?background-color:\s*?blue;\s*?top:\s*?0(px)?;\s*?left:\s*?0(px)?;\s*?}/gi
  )
);

50%@keyframes 规则应为向 left 偏移 25px

assert(
  code.match(
    /50%\s*?{\s*?background-color:\s*?green;\s*?top:\s*?50px;\s*?left:\s*?25px;\s*?}/gi
  )
);

100%@keyframes 规则应为向 left 偏移 -25px

assert(
  code.match(
    /100%\s*?{\s*?background-color:\s*?yellow;\s*?top:\s*?0(px)?;\s*?left:\s*?-25px;\s*?}/gi
  )
);

--seed--

--seed-contents--

<style>
  div {
    height: 40px;
    width: 70%;
    background: black;
    margin: 50px auto;
    border-radius: 5px;
    position: relative;
  }

  #rect {
    animation-name: rainbow;
    animation-duration: 4s;
  }

  @keyframes rainbow {
    0% {
      background-color: blue;
      top: 0px;

    }
    50% {
      background-color: green;
      top: 50px;

    }
    100% {
      background-color: yellow;
      top: 0px;

    }
  }
</style>

<div id="rect"></div>

--solutions--

<style>
  div {
    height: 40px;
    width: 70%;
    background: black;
    margin: 50px auto;
    border-radius: 5px;
    position: relative;
  }

  #rect {
    animation-name: rainbow;
    animation-duration: 4s;
  }

  @keyframes rainbow {
    0% {
      background-color: blue;
      top: 0px;
      left: 0px;
    }
    50% {
      background-color: green;
      top: 50px;
      left: 25px;
    }
    100% {
      background-color: yellow;
      top: 0px;
      left: -25px;
    }
  }
</style>
<div id="rect"></div>