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 の設定が重要です。