freeCodeCamp/curriculum/challenges/japanese/01-responsive-web-design/applied-visual-design/modify-fill-mode-of-an-anim...

2.4 KiB

id title challengeType videoUrl forumTopicId dashedName
58a7a6ebf9a6318348e2d5aa アニメーションの Fill モードを変更する 0 https://scrimba.com/c/cVJDmcE 301064 modify-fill-mode-of-an-animation

--description--

素晴らしい!でも、まだうまくいきませんね。 500ms が過ぎるとアニメーションがリセットされ、ボタンが元の色に戻ることに注目してください。 ボタンをハイライト表示のままにしたいと思うでしょう。

animation-fill-mode プロパティを forwards に設定すると、そのようにできます。 animation-fill-mode は、アニメーションが終わった時に要素に適用されるスタイルを指定します。 次のように設定できます:

animation-fill-mode: forwards;

--instructions--

button:hoveranimation-fill-mode プロパティを forwards に設定して、ユーザーがボタンにホバーするとボタンがハイライトされたままになるようにしましょう。

--hints--

button:hover は、値が forwardsanimation-fill-mode プロパティを持つ必要があります。

assert(
  code.match(
    /button\s*?:\s*?hover\s*?{[\s\S]*animation-fill-mode\s*?:\s*?forwards\s*?;[\s\S]*}/gi
  ) &&
    code.match(
      /button\s*?:\s*?hover\s*?{[\s\S]*animation-name\s*?:\s*?background-color\s*?;[\s\S]*}/gi
    ) &&
    code.match(
      /button\s*?:\s*?hover\s*?{[\s\S]*animation-duration\s*?:\s*?500ms\s*?;[\s\S]*}/gi
    )
);

--seed--

--seed-contents--

<style>
  button {
    border-radius: 5px;
    color: white;
    background-color: #0F5897;
    padding: 5px 10px 8px 10px;
  }
  button:hover {
    animation-name: background-color;
    animation-duration: 500ms;
    /* Only change code below this line */

    /* Only change code above this line */
  }
  @keyframes background-color {
    100% {
      background-color: #4791d0;
    }
  }
</style>
<button>Register</button>

--solutions--

<style>
  button {
    border-radius: 5px;
    color: white;
    background-color: #0F5897;
    padding: 5px 10px 8px 10px;
  }
  button:hover {
    animation-name: background-color;
    animation-duration: 500ms;
    animation-fill-mode: forwards;
  }
  @keyframes background-color {
    100% {
      background-color: #4791d0;
    }
  }
</style>
<button>Register</button>