cssでタブを実装したコピペサンプル[5つのパターンを用意]

f:id:media-gatch:20181121171754j:plain

どうもー・ω・ガッチ(@MediaGatch)です。

cssフェードインアニメーションの記事が好評だったので、WEBサイトでよく使用するタブのサンプルを作成しました。

cssだけでタブメニューを作成したい。できればレスポンシブ対応したタブメニューを作成したい。そんな方へ向けた記事です。

css初心者でも簡単に使えるコピペサンプルを紹介してますので、ぜひ使ってみてください。コメントやシェアしてもらえたら泣いて喜びます(T ^ T)

cssのフェードインアニメーションが気になる方はこちらもどうぞ。

>>cssでフェードインアニメーションの実装方法[コピペサンプルあり]

記事の内容はこちら

cssのタブサンプル

f:id:media-gatch:20181121172055j:plain cssだけで作成できるタブを5つ載せています。コピペで使用可ですので、気になった方はぜひ使ってくださいね。 どのサンプルもレスポンシブ対応してます。

タブサンプル① メニュー表示 通信あり(aタグ)

タブの基本形サンプルです。 WWEBサイトのメニュー等で使われることが多いのではないでしょうか。 タブ内のaタグで各ページへリンクさせます。

デモページでは、ページの移動がないので、動作しませんが、、、 ページごとに、 tab-body 内を変更して使ってください。

タブのコンテンツのページごとに作成します。

<ul class="tab">
  <li class="tab__item on"><a class="tab__link" href="#">タブ1</a></li>
  <li class="tab__item"><a class="tab__link" href="#">タブ2</a></li>
  <li class="tab__item"><a class="tab__link" href="#">タブ3</a></li>
  <li class="tab__item"><a class="tab__link" href="#">タブ4</a></li>
  <li class="tab__item"><a class="tab__link" href="#">タブ5</a></li>
</ul>
<div class="tab-body">
  タブのコンテンツのページごとに作成します。
</div>
<style>
.tab{
  list-style: none;
  padding:0;
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.tab__item{
  flex:1;
  flex-basis: 120px;
  background-color:#65c6ba;
}
.tab__item.on{
  background-color:#b1e2dc;
}
.tab__link{
  display: block;
  text-decoration: none;
  color: #fff;
}
.tab__link:visited{
  color: #fff;
}
</style>

タブサンプル② メニュー表示 通信なし(js制御)

上記タブメニューの通信を行わないパターンのサンプルです。 タブ内の表示切り替えをjsを使用して行ってます。jsの制御は、jQueryを使用してます。

ページを作るまでもないけど、ページを見やすくしたい場合などに使えるのではないでしょうか。 スクロール量が異常に長い!というようなページなどに。

下記がデモになります。タブをクリックして確認できます。

  • タブ1
  • タブ2
  • タブ3
  • タブ4
  • タブ5
タブ1のコンテンツ内容です。
タブ2のコンテンツ内容です。
タブ3のコンテンツ内容です。
タブ4のコンテンツ内容です。
タブ5のコンテンツ内容です。

<ul class="tab">
  <li class="tab__item on" data-tab-body="js-tab-body-1">タブ1</li>
  <li class="tab__item" data-tab-body="js-tab-body-2">タブ2</li>
  <li class="tab__item" data-tab-body="js-tab-body-3">タブ3</li>
  <li class="tab__item" data-tab-body="js-tab-body-4">タブ4</li>
  <li class="tab__item" data-tab-body="js-tab-body-5">タブ5</li>
</ul>
<div class="tab-body">
  <div id="js-tab-body-1" class="tab-body__item on">
    タブ1のコンテンツ内容です。
  </div>
  <div id="js-tab-body-2" class="tab-body__item">
    タブ2のコンテンツ内容です。
  </div>
  <div id="js-tab-body-3" class="tab-body__item">
    タブ3のコンテンツ内容です。
  </div>
  <div id="js-tab-body-4" class="tab-body__item">
    タブ4のコンテンツ内容です。
  </div>
  <div id="js-tab-body-5" class="tab-body__item">
    タブ5のコンテンツ内容です。
  </div>
<style>
.tab{
  list-style: none;
  padding:0;
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.tab__item{
  flex:1;
  flex-basis: 120px;
  background-color:#65c6ba;
  cursor: pointer;
}
.tab__item.on{
  background-color:#b1e2dc;
}
.tab-body__item{
  display: none;
}
.tab-body__item.on{
  display:block;
}
</style>
<script>
$(function(){
  var $tab_item = $(".tab__item");
  var $tab_body_item = $(".tab-body__item");
  $tab_item.on("click",function(e){
    var target = $(e.currentTarget);
    //タブの表示非表示
    $tab_item.removeClass("on");
    target.addClass("on");
    //タブの中身の表示非表示
    var name = target.data("tab-body");
    $tab_body_item.removeClass("on");
    $("#"+name).addClass("on");
  });
});
</script>

タブサンプル③ 台形表示 非同期通信 loading表示なし

タブ内のhtmlだけを通信で取得して表示を切り替えるサンプルです。 jsを使用して通信の制御をするので少し複雑になるけれど部分的な通信になるので、高速に表示できる可能性が高いです。 サンプルでは、jQueryajax通信を使用してます。

デモでは、ガッチサイトの別ページを読み込んできて、タブの下に表示するようにしています。 タブをクリックして確認できますので、お試しください。

  • タブ1
  • タブ2
  • タブ3
  • タブ4
  • タブ5
タブのコンテンツのページごとに作成します。

<!-- data-tab-urlを変えて使ってね -->
<ul class="tab">
  <li class="tab__item on" data-tab-url="https://www.yahoo.co.jp/">タブ1</li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ2</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ3</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ4</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ5</a></li>
</ul>
<div id="js-tab-body" class="tab-body">
  タブのコンテンツのページごとに作成します。
</div>
<style>
.tab{
  list-style: none;
  padding:0;
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.tab__item{
  flex:1;
  /* 台形部分 */
  height: 0;
  line-height: 40px;
  border-bottom: 40px solid #65c6ba;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top-left-radius:25px 35px;
  border-top-right-radius:25px 35px;
  cursor: pointer;
}
.tab__item.on{
  border-bottom: 40px solid #b1e2dc;
}
.tab__link{
  display: block;
  text-decoration: none;
  color: #fff;
}
.tab-body{
  height:480px;
  overflow: scroll;
}
</style>
<script>
$(function(){
  var $tab_item = $(".tab__item");
  var $tab_body = $("#js-tab-body");
  $tab_item.on("click",function(e){
    var target = $(e.currentTarget);
    //タブの表示非表示
    $tab_item.removeClass("on");
    target.addClass("on");
    //通信制御
    var url = target.data("tab-url");
    $.ajax({
      url:url,
    })
    // ajax成功後
    .done( function(data){
      $tab_body.html(data);
    });
  });
});
</script>

タブサンプル④ 台形表示 非同期通信 loading表示あり

先ほどの非同期通信(ajax通信)サンプルにの通信中にloading表示を追加したサンプルです。 loading表示の方法は様々あるんですが、今回はシンプルな方法で実装しています。

デモでは、 tab-body のdivタグ背景に、loadingのアニメーションgifをcssで実装し、 その表示を切り開けるだけのシンプルな方法です。

タブをクリックしてご確認ください。

  • タブ1
  • タブ2
  • タブ3
  • タブ4
  • タブ5
タブのコンテンツのページごとに作成します。

<!-- data-tab-urlを変えて使ってね -->
<ul class="tab">
  <li class="tab__item on" data-tab-url="https://www.yahoo.co.jp/">タブ1</li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ2</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ3</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ4</a></li>
  <li class="tab__item" data-tab-url="https://www.yahoo.co.jp/">タブ5</a></li>
</ul>
<div id="js-tab-body" class="tab-body">
  タブのコンテンツのページごとに作成します。
</div>
<style>
.tab{
  list-style: none;
  padding:0;
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.tab__item{
  flex:1;
  /* 台形部分 */
  height: 0;
  line-height: 40px;
  border-bottom: 40px solid #65c6ba;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top-left-radius:25px 35px;
  border-top-right-radius:25px 35px;
  cursor: pointer;
}
.tab__item.on{
  border-bottom: 40px solid #b1e2dc;
}
.tab__link{
  display: block;
  text-decoration: none;
  color: #fff;
}
.tab-body{
  height:480px;
  overflow: scroll;
}
.tab-body.loading{
  background-image: url("");
  background-position: center;
  background-repeat: no-repeat;
}
</style>
<script>
$(function(){
  var $tab_item = $(".tab__item");
  var $tab_body = $("#js-tab-body");
  $tab_item.on("click",function(e){
    var target = $(e.currentTarget);
    //loading表示の切り替え
    $tab_body.empty().addClass("loading");
    //タブの表示非表示
    $tab_item.removeClass("on");
    target.addClass("on");
    //通信制御
    var url = target.data("tab-url");
    $.ajax({
      url:url,
    })
    // ajax成功後
    .done( function(data){
      $tab_body.html(data).removeClass("loading");
    });
  });
});
</script>

タブサンプル⑤ フロートメニュー表示

タブは画面上部のメニューとして使用することが多いかと思います。 ただ、スクロールすると消えてしまう。。。

このサンプルでは、メニューが消えてしまわないように、スクロールに追従してくるようにしています。

実装は簡単で、cssposition:sticky; を使っているだけ笑。 これを使うだけでサイトが少しリッチに見えますね^^

  • タブ1
  • タブ2
  • タブ3
  • タブ4
  • タブ5
タブのコンテンツのページごとに作成します。
コンテンツサンプル

<div class="tab-sticky">
  <ul class="tab">
  <li class="tab__item on" data-tab-url="https://www.gatch.site">タブ1</li>
  <li class="tab__item" data-tab-url="https://www.gatch.site/entry/css-class-naming">タブ2</a></li>
  <li class="tab__item" data-tab-url="https://www.gatch.site/entry/seo-internal-h1">タブ3</a></li>
  <li class="tab__item" data-tab-url="https://www.gatch.site/entry/css-fadein-animation">タブ4</a></li>
  <li class="tab__item" data-tab-url="https://www.gatch.site/entry/vscode-initial-setting">タブ5</a></li>
</ul>
</div>
<div id="js-tab-body" class="tab-body">
  タブのコンテンツのページごとに作成します。
</div>
<div class="content">
  コンテンツサンプル
</div>
<style>
.tab-sticky{
  position: sticky;
  top:10px;
}
.tab{
  list-style: none;
  padding:0;
  text-align: center;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
}
.tab__item{
  flex:1;
  /* 台形部分 */
  height: 0;
  line-height: 40px;
  border-bottom: 40px solid #65c6ba;
  border-left: 12px solid transparent;
  border-right: 12px solid transparent;
  border-top-left-radius:25px 35px;
  border-top-right-radius:25px 35px;
  cursor: pointer;
}
.tab__item.on{
  border-bottom: 40px solid #b1e2dc;
}
.tab__link{
  display: block;
  text-decoration: none;
  color: #fff;
}
.tab-body{
  text-align: center;
  height:300px;
  overflow: scroll;
}
.tab-body.loading{
  background-image: url("");
  background-position: center;
  background-repeat: no-repeat;
}
.content{
  height: 800px;
  text-align: center;
  background-color: #ccc;
}
</style>