JavaScriptでタブを作成する方法


まず、タブの基本的な機能を実装する方法から始めましょう。以下のコード例をご覧ください。

<!DOCTYPE html>
<html>
<head>
<style>
.tab {
  overflow: hidden;
  border: 1px solid #ccc;
  background-color: #f1f1f1;
}
.tab button {
  background-color: inherit;
  float: left;
  border: none;
  outline: none;
  cursor: pointer;
  padding: 14px 16px;
  transition: 0.3s;
}
.tab button:hover {
  background-color: #ddd;
}
.tab button.active {
  background-color: #ccc;
}
.tabcontent {
  display: none;
  padding: 6px 12px;
  border: 1px solid #ccc;
  border-top: none;
}
</style>
</head>
<body>
<h2>タブの例</h2>
<div class="tab">
  <button class="tablinks" onclick="openTab(event, 'Tab1')">タブ1</button>
  <button class="tablinks" onclick="openTab(event, 'Tab2')">タブ2</button>
  <button class="tablinks" onclick="openTab(event, 'Tab3')">タブ3</button>
</div>
<div id="Tab1" class="tabcontent">
  <h3>タブ1のコンテンツ</h3>
  <p>ここにタブ1のコンテンツを記述します。</p>
</div>
<div id="Tab2" class="tabcontent">
  <h3>タブ2のコンテンツ</h3>
  <p>ここにタブ2のコンテンツを記述します。</p>
</div>
<div id="Tab3" class="tabcontent">
  <h3>タブ3のコンテンツ</h3>
  <p>ここにタブ3のコンテンツを記述します。</p>
</div>
<script>
function openTab(evt, tabName) {
  var i, tabcontent, tablinks;
  tabcontent = document.getElementsByClassName("tabcontent");
  for (i = 0; i < tabcontent.length; i++) {
    tabcontent[i].style.display = "none";
  }
  tablinks = document.getElementsByClassName("tablinks");
  for (i = 0; i < tablinks.length; i++) {
    tablinks[i].className = tablinks[i].className.replace(" active", "");
  }
  document.getElementById(tabName).style.display = "block";
  evt.currentTarget.className += " active";
}
</script>
</body>
</html>

上記のコードは、タブを作成するための基本的なHTMLとCSSを提供しています。JavaScriptのopenTab関数は、クリックされたタブを表示し、他のタブを非表示にする機能を実装しています。

このコードを使用すると、ウェブページに3つのタブが表示されます。各タブをクリックすると、対応するコンテンツが表示されます。

この方法を拡張することで、さまざまなスタイルや機能を持つカスタムタブを作成できます。例えば、動的にタブを追加したり、外部のデータを読み込んでタブのコンテンツを生成したりすることも可能です。

このコード例と説明を参考にしながら、自分のウェブページにタブを実装してみてください。