HTMLのテーブルの縦横スクロールを固定する方法

HTMLのテーブルの縦横スクロールを固定する方法

HTMLテーブルで縦横スクロールを固定する方法について、HTMLとCSSを別ファイルに分けて、テーブルのヘッダーと列をスクロールするように設定する方法を説明します。
具体的な例を交えて説明します。

HTMLファイル (index.html)

まずはHTMLファイルです。
このファイルには、テーブルの構造と基本的なマークアップが含まれています。
テーブルのデータを含むtable要素があり、その上に固定するヘッダーを含むためのdivを用意します。

<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>テーブルのスクロール固定</title>
  <link rel="stylesheet" href="styles.css">
</head>
<body>
  <div class="test-table-container">
    <div class="test-table-wrapper">
      <table class="test-table">
        <thead>
          <tr>
            <th class="test-header">ヘッダー1</th>
            <th class="test-header">ヘッダー2</th>
            <th class="test-header">ヘッダー3</th>
            <th class="test-header">ヘッダー4</th>
          </tr>
        </thead>
        <tbody>
          <tr>
            <td class="test-cell">データ1</td>
            <td class="test-cell">データ2</td>
            <td class="test-cell">データ3</td>
            <td class="test-cell">データ4</td>
          </tr>
          <!-- 他の行をここに追加 -->
        </tbody>
      </table>
    </div>
  </div>
</body>
</html>

CSSファイル (styles.css)

次に、CSSファイルです。
ここでは、スクロール固定を実現するために、テーブルのスクロールを設定し、ヘッダーと列を固定します。

.test-table-container {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow: hidden;
}

.test-table-wrapper {
  position: relative;
  max-height: 400px; /* 固定する高さ */
  overflow-y: auto; /* 縦方向のスクロールを有効にする */
}

.test-table {
  border-collapse: collapse;
  width: 100%;
  min-width: 600px; /* 横方向の最小幅を設定 */
}

.test-header, .test-cell {
  border: 1px solid #ddd;
  padding: 8px;
}

.test-header {
  position: sticky;
  top: 0;
  background: #f9f9f9;
  z-index: 1; /* ヘッダーを他のコンテンツの上に表示 */
}

.test-table-wrapper::after {
  content: "";
  display: block;
  height: 20px; /* スクロールバーの高さ分のスペースを確保 */
  background: #fff;
}

.test-table {
  border-collapse: collapse;
  width: 100%;
}

.test-table td, .test-table th {
  border: 1px solid #ddd;
  padding: 8px;
}

.test-table tbody {
  display: block;
  overflow-x: auto;
  white-space: nowrap;
}

.test-table thead, .test-table tbody tr {
  display: table;
  width: 100%;
  table-layout: fixed;
}

.test-table tbody {
  max-height: 200px; /* 縦方向のスクロールを有効にする高さ */
  overflow-y: auto; /* 縦方向のスクロールを有効にする */
}

説明

1. HTML構造:
test-table-container クラスを持つ div 要素でテーブルをラップし、スクロールコンテナとして設定します。
test-table-wrapper クラスを持つ div 要素内にテーブルを配置し、これにより縦方向のスクロールを実現します。

2. CSSスタイリング:

  • .test-table-container は、スクロールを含むコンテナで、overflow: hidden で内部のスクロールを制御します。
  • .test-table-wrapper では、max-height と overflow-y: auto を設定し、縦方向のスクロールを可能にします。
  • .test-table でテーブル全体のスタイルを設定します。

ここでは border-collapse: collapse を使用し、セルのボーダーが重ならないようにします。

  • .test-header は、position: sticky と top: 0 を使用してヘッダーを固定し、テーブルがスクロールしてもヘッダーが画面の上部に留まるようにします。
  • .test-table tbody で display: block と overflow-x: auto を設定し、横方向のスクロールを有効にします。
  • .test-table thead, .test-table tbody tr で display: table と table-layout: fixed を設定し、ヘッダーとテーブルの行が揃うようにします。

この設定により、テーブルのヘッダーは固定され、データ部分はスクロール可能になります。
縦横両方向でスクロールを維持するためには、display: block や overflow の設定が重要です。