カテゴリ: CSS 更新日: 2026/04/25

CSSアニメーションと擬似クラスの使い方を完全ガイド!初心者でも動きが作れる方法

CSSアニメーションと擬似クラスを組み合わせて動きをつける方法
CSSアニメーションと擬似クラスを組み合わせて動きをつける方法

先生と生徒の会話形式で理解しよう

生徒

「ホームページのボタンにマウスを乗せたときに、ふわっと動かしたり色を変えたりしたいです!」

先生

「それはCSSアニメーションと擬似クラスを使えば実現できますよ。初心者の方でも、ルールを覚えれば簡単に動きをつけることができます。」

生徒

「難しそうな単語が出てきましたが、プログラミングをやったことがない私でも大丈夫でしょうか?」

先生

「大丈夫です!一つずつ丁寧に、パソコンを触ったことがない方にもわかるように解説していきますね。まずは基本的な考え方から見ていきましょう。」

1. 擬似クラスとは何かを分かりやすく解説

1. 擬似クラスとは何かを分かりやすく解説
1. 擬似クラスとは何かを分かりやすく解説

Webサイトのデザインを作るとき、通常は「この文字を赤くする」という指示を出します。しかし、「マウスが乗ったときだけ赤くする」というように、何か条件が加わったときにだけデザインを変えたいことがあります。この条件を指定する特別な書き方が「擬似クラス(ぎじくらす)」です。

パソコンの操作で、マウスの矢印をボタンの上に重ねる動作を「ホバー」と言います。このホバーした瞬間にだけ魔法をかける命令が :hover(ホバー) という擬似クラスです。これを使うことで、ユーザーが「今、自分はこのボタンを触っているんだな」と直感的に理解できる、親切なホームページを作ることができるようになります。まずはこの「きっかけ」を作る方法が基本になります。

2. transitionを使って滑らかな変化を作る方法

2. transitionを使って滑らかな変化を作る方法
2. transitionを使って滑らかな変化を作る方法

色がいきなりパッと変わるよりも、映画のワンシーンのように「ふわっ」と滑らかに変わる方が、高級感があってオシャレに見えますよね。この変化の時間をコントロールする設定transition(トランジション) です。

例えば「0.5秒かけて色を変えてください」と指示を出すことができます。これを設定しないと、一瞬で色が変わってしまい、少し安っぽい印象を与えてしまうことがあります。プログラミング未経験の方でも、この「時間の設定」を加えるだけで、一気にプロっぽい仕上がりになります。まずはボタンの色がゆっくり変わる簡単なコードを書いてみましょう。


<style>
.soft-button {
    background-color: #007bff;
    color: white;
    padding: 10px 20px;
    border: none;
    cursor: pointer;
    /* 変化に0.5秒かけるという魔法の言葉 */
    transition: 0.5s;
}

.soft-button:hover {
    background-color: #0056b3;
    /* マウスが乗った時に少し大きくする */
    transform: scale(1.1);
}
</style>

<div class="p-3">
    <button class="soft-button">ゆっくり色が変わるボタン</button>
</div>
ブラウザ表示

3. 繰り返し動くアニメーションの作り方

3. 繰り返し動くアニメーションの作り方
3. 繰り返し動くアニメーションの作り方

ボタンを触ったときだけでなく、最初からずっとプルプル震えていたり、ふわふわ浮いていたりするような動きを作りたいときは、keyframes(キーフレーム) という仕組みを使います。これは、アニメーターがパラパラ漫画を描くように「0パーセントのときはこの形、100パーセントのときはこの形」と、動きの設計図を作る作業です。

この設計図に名前をつけて、好きな場所に呼び出すことができます。例えば「ドキドキ」という名前の設計図を作って、それを画像に適用すれば、まるで心臓のように動く画像が完成します。プログラミングの難しい理論ではなく、図形がどう動いてほしいかを言葉で書いていくイメージです。以下の例では、ずっとふわふわ浮いているような動きを作っています。


<style>
/* ふわふわ動く設計図を作ります */
@keyframes fuwafuwa {
    0% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
    100% { transform: translateY(0); }
}

.float-card {
    width: 200px;
    padding: 20px;
    background-color: #f8f9fa;
    border: 1px solid #ddd;
    text-align: center;
    /* 設計図を呼び出して、2秒かけてずっと繰り返す設定 */
    animation: fuwafuwa 2s infinite;
}
</style>

<div class="p-4">
    <div class="float-card">
        ふわふわ浮いています
    </div>
</div>
ブラウザ表示

4. transformを使って図形を自在に操るテクニック

4. transformを使って図形を自在に操るテクニック
4. transformを使って図形を自在に操るテクニック

アニメーションでよく使われるのが transform(トランスフォーム) という命令です。これは日本語で「変形」という意味です。文字を回転させたり、左右に動かしたり、拡大・縮小したりする機能を持っています。

例えば、rotate(ロテート) と書けば回転しますし、scale(スケール) と書けば大きさが変わります。これらの命令をアニメーションの設計図(キーフレーム)の中に書き込むことで、「最初は小さくて、最後は大きくなる」といった演出が可能になります。パソコンを触り始めたばかりの方でも、単語の意味が分かれば操作は簡単です。図形を自由に動かせるようになると、Web制作がパズル遊びのように楽しくなります。

5. 擬似クラスでアニメーションをスタートさせる応用

5. 擬似クラスでアニメーションをスタートさせる応用
5. 擬似クラスでアニメーションをスタートさせる応用

「普段は止まっているけれど、マウスが乗ったときだけ激しく動かしたい」という場合は、擬似クラスのホバーと、先ほどの設計図(アニメーション)を組み合わせます。これにより、ユーザーの操作に反応して動き出す、面白い仕掛けが作れます。

例えば、普段は静止しているアイコンにマウスを重ねると、ブルブル震えて「クリックして!」とアピールするような演出です。これは animation-play-state(アニメーション・プレイ・ステート) という命令を組み合わせて使うこともできますが、もっとも簡単なのは、ホバーした瞬間にアニメーションの名前を登録する方法です。実際にアイコンが回転する例を作ってみましょう。


<style>
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.spin-icon {
    font-size: 50px;
    display: inline-block;
    transition: 0.5s;
}

/* ホバーしたときだけ回転アニメーションを動かす */
.spin-icon:hover {
    animation: spin 1s linear infinite;
    color: orange;
}
</style>

<div class="p-4 text-center">
    <div class="spin-icon">
        <i class="bi bi-gear-fill"></i>
    </div>
    <p>歯車にマウスを乗せてみてね</p>
</div>
ブラウザ表示

6. アニメーションを自然に見せるイージングの秘密

6. アニメーションを自然に見せるイージングの秘密
6. アニメーションを自然に見せるイージングの秘密

物が動くとき、最初から最後まで同じ速度で動くのは、ロボットのようで少し不自然に見えることがあります。現実の世界では、車も走り出しはゆっくりで、徐々にスピードが上がりますよね。この「速度の変化の付け方」を イージング と呼びます。

CSSでは ease-in(イーズ・イン)ease-out(イーズ・アウト) という言葉を使って、この自然な動きを簡単に再現できます。プログラミングの難しい計算は一切不要です。ただ単語を書き添えるだけで、プロのクリエイターが作ったような、滑らかで気持ちの良いアニメーションに仕上がります。細部までこだわることで、ホームページを訪れた人の心地よさが変わってきます。

7. 透明度を使ってフェードイン演出を作る

7. 透明度を使ってフェードイン演出を作る
7. 透明度を使ってフェードイン演出を作る

アニメーションで一番使いやすいのが、パッと表示されるのではなく、霧の中から現れるように表示させる「フェードイン」です。これには opacity(オパシティ) という命令を使います。これは日本語で「不透明度」のことです。

最初は opacity: 0(透明で見えない状態)にしておき、アニメーションの最後で opacity: 1(完全に表示される状態)にします。この設定は、ページのタイトルをドラマチックに見せたいときや、画像をおしゃれに並べたいときに非常に役立ちます。初心者の方でもすぐに使える、魔法のようなテクニックの一つです。


<style>
@keyframes fadeIn {
    0% { opacity: 0; transform: scale(0.5); }
    100% { opacity: 1; transform: scale(1); }
}

.fade-box {
    width: 150px;
    height: 100px;
    background-color: #28a745;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 15px;
    /* 読み込まれた時に1回だけ実行する */
    animation: fadeIn 1.5s ease-out forwards;
}
</style>

<div class="p-4">
    <div class="fade-box">
        現れました!
    </div>
</div>
ブラウザ表示

8. 動きすぎに注意!ユーザーに優しい設計とは

8. 動きすぎに注意!ユーザーに優しい設計とは
8. 動きすぎに注意!ユーザーに優しい設計とは

アニメーションは楽しいですが、使いすぎには注意が必要です。画面のあちこちで激しく動きすぎていると、読んでいる人はどこを見ていいのか分からなくなり、目が疲れてしまいます。ホームページの主役はあくまで「内容」であることを忘れないようにしましょう。

大切なのは「ここが重要だよ」とさりげなく伝えることです。また、パソコンが苦手な方や、目が疲れやすい方のために、動きを控えめにすることも一つの「おもてなし」です。まずはボタンを少し浮かせたり、色をゆっくり変えたりするところから始めて、自分も周りの人も「使いやすい」と感じるバランスを見つけてみてください。楽しみながら少しずつ練習していけば、きっと素晴らしいWebデザインができるようになりますよ。

2026年最新 スキルアップ・実践セミナー

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

「魅せる力」をコードで実現。CSS3でモダンWebデザインのプロトタイピングを。

本講座では、単に色を変えるだけではなく、「ユーザーを迷わせないUIデザイン」「崩れないレイアウト設計」の本質を学びます。最新のCSS3とモダンなレイアウト手法を通じて、プロの現場で通用する「美しさと機能性を両立した実装力」を最短距離で習得します。

具体的なワークショップ内容と環境

【つくるもの】
HTMLで作成した骨組みに対し、商用サイトでも採用される「スタイリッシュなカード型UI」や「レスポンシブなナビゲーション」を構築します。色の選定基準や余白(ホワイトスペース)の黄金比など、デザインの理論をコードに落とし込む工程を体験してください。

【開発環境】
フロントエンド開発の標準であるVisual Studio Code (VS Code)を継続使用。CSSの記述を効率化するプラグインや、ブラウザのデベロッパーツール(検証機能)を駆使して、リアルタイムでデザインを微調整するプロのワークフローを再現します。

この60分で得られる3つの技術資産

1. 現代のデファクトスタンダード「Flexbox」

要素の横並びや中央揃えを自由自在に操り、どんなデバイスでも崩れないレスポンシブな配置術を完全理解します。

2. メンテナンス性を高めるCSS設計の基礎

後から修正しやすい「壊れにくいコード」の書き方を伝授。プロの現場で必須となる命名規則の考え方を学びます。

3. パフォーマンスと美しさの両立

画像の最適化や軽量な装飾技法など、ページの表示速度を落とさずに高級感のある演出を行うテクニックを習得します。

※本講座は、HTMLの基礎を終えた後のステップアップ講座です。Webデザイナー、UIデザイナー、フロントエンドエンジニアへの道を切り開く「魅せる技術」を、モクモク独自のパーソナル指導で着実に定着させます。

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

リラックスしながら、学ぶことが大切です。しっかりと基礎を理解しましょう!

各回少人数・マンツーマン形式で徹底サポート

このセミナーの詳細・お申し込みはこちら
カテゴリの一覧へ
新着記事
New1
Bootstrap
Bootstrap移行ガイド!IEサポート終了の影響と代替実装・ポリフィルの考え方
New2
CSS
CSSでグリッド・フレックスと組み合わせたマージン最適化テクニック!初心者でもわかる余白調整
New3
Bootstrap
Bootstrapオフキャンバス完全入門|バックドロップ・スクロール・キーボード設定をやさしく解説
New4
CSS
CSSで見出し・段落・リストのマージン調整を完全解説!初心者でも理解できる基本
人気記事
No.1
Java&Spring記事人気No1
CSS
CSSで要素のサイズを自動調整!autoとfit-contentの使い方
No.2
Java&Spring記事人気No2
CSS
CSSの透明度を完全解説!初心者にもわかるopacityとrgbaの使い方
No.3
Java&Spring記事人気No3
CSS
CSSでGoogle Fontsを使う方法を完全ガイド!初心者でもできるフォントの変更
No.4
Java&Spring記事人気No4
HTML
HTMLのimgタグの書き方|src・altの必須属性を初心者向けにやさしく整理
No.5
Java&Spring記事人気No5
CSS
CSSで色の明るさや鮮やかさを自由に調整!初心者向けHSLカラー指定の完全ガイド
No.6
Java&Spring記事人気No6
Bootstrap
ReactでBootstrapを使う方法を解説!初心者でもわかるreact-bootstrapと本体の違い
No.7
Java&Spring記事人気No7
CSS
CSSのレイアウト基本パターンを完全ガイド!初心者でもわかる2カラム・3カラムの作り方
No.8
Java&Spring記事人気No8
CSS
CSSのダブルボーダーや点線・破線を完全ガイド!初心者でもわかるdotted・dashed・doubleの使い方