スマートフォンのモック
シンプルなタブ
上線ありのタブ

HTML・CSSでつくる切り替え可能なタブのデザイン2選

  • HTML
  • CSS
  • カラー調整対応
  • レスポンシブ対応
  • JavaScript不要

「ここの要素をユーザーが表示・非表示を切り替えできるようにしたい」という場合におすすめなのがタブメニュー。ユーザーに必要な要素のみを表示できるのが特徴で、よりサイトをスタイリッシュにすることができます。比較的実装に手間がかかるタブですが、コピペで完結する本ジェネレーターでお手軽に導入してみてください。

シンプルなタブ

シンプルなタブ

  1. デザイン調整
  2. HTMLをコピペ
  3. CSSをコピペ
  4. 完了
step1
デザインを調整する
背景が単色のシンプルなタブです。 タブの文言がはっきり見えるだけでなく、色を変えることでどんなサイトにも馴染みやすいのが特徴です。
ぜひタブの背景色をお好みのものに変えてみてください。
もちろんレスポンシブ対応で、タブの追加にも対応しています。
デモページ
step2
HTMLをコピペする
HTML
<div class="tab-002">
    <label>
        <input type="radio" name="tab-002" checked>
        タブ1
    </label>
    <div>
        背景が単色のシンプルなタブです。
        タブの文言がはっきり見えるだけでなく、色を変えることでどんなサイトにも馴染みやすいのが特徴です。
    </div>

    <label>
        <input type="radio" name="tab-002">
        タブ2
    </label>
    <div>ぜひタブの背景色をお好みのものに変えてみてください。</div>

    <label>
        <input type="radio" name="tab-002">
        タブ3
    </label>
    <div>もちろんレスポンシブ対応で、タブの追加にも対応しています。</div>
</div>
step3
CSSをコピペする
CSS
.tab-002 {
    display: flex;
    flex-wrap: wrap;
    gap: 0 10px;
    max-width: 500px;
}

.tab-002 > label {
    flex: 1 1;
    order: -1;
    opacity: .5;
    min-width: 70px;
    padding: .6em 1em;
    border-radius: 5px 5px 0 0;
    background-color: #2589d0;
    color: #fff;
    text-align: center;
    cursor: pointer;
}

.tab-002 > label:hover {
    opacity: .8;
}

.tab-002 input {
    display: none;
}

.tab-002 > div {
    display: none;
    width: 100%;
    padding: 2em 1.5em;
    background-color: #fff;
}

.tab-002 label:has(:checked) {
    opacity: 1;
}

.tab-002 label:has(:checked) + div {
    display: block;
}
上線ありのタブ

上線ありのタブ

step1
デザインを調整する
上に枠線の付いたタプです。現在表示されているタブがどれなのか判別しやすいのが特徴。 背景が白以外の箇所で利用するとよりおしゃれに見えます。
ぜひ線の色をお好みの色に変えてみてください。
もちろんレスポンシブ対応で、タブの追加にも対応しています。
デモページ
step2
HTMLをコピペする
HTML
<div class="tab-001">
    <label>
        <input type="radio" name="tab-001" checked>
        タブ1
    </label>
    <div>
        上に枠線の付いたタプです。現在表示されているタブがどれなのか判別しやすいのが特徴。
        背景が白以外の箇所で利用するとよりおしゃれに見えます。
    </div>

    <label>
        <input type="radio" name="tab-001">
        タブ2
    </label>
    <div>ぜひ線の色をお好みの色に変えてみてください。</div>

    <label>
        <input type="radio" name="tab-001">
        タブ3
    </label>
    <div>もちろんレスポンシブ対応で、タブの追加にも対応しています。</div>
</div>
step3
CSSをコピペする
CSS
.tab-001 {
    display: flex;
    flex-wrap: wrap;
    max-width: 500px;
}

.tab-001 > label {
    flex: 1 1;
    order: -1;
    min-width: 70px;
    padding: .6em 1em .4em;
    border-bottom: 1px solid #f0f0f0;
    border-radius: 0;
    background-color: #e9f0f6;
    color: #535353;
    text-align: center;
    cursor: pointer;
}

.tab-001 > label:hover {
    opacity: .8;
}

.tab-001 input {
    display: none;
}

.tab-001 > div {
    display: none;
    width: 100%;
    padding: 2em 1.5em;
    background-color: #fff;
}

.tab-001 label:has(:checked) {
    background-color: #fff;
    border-color: #2589d0 #f0f0f0 #fff;
    border-style: solid;
    border-width: 4px 1px 1px;
    border-radius: 5px;
    color: #333333;
}

.tab-001 label:has(:checked) + div {
    display: block;
}