CSS-テーブル

このチュートリアルでは、CSSを使用してHTMLテーブルのさまざまなプロパティを設定する方法を説明します。テーブルの次のプロパティを設定できます-

  • ザ・ border-collapse 互いに接触する隣接する境界線の外観をブラウザが制御するかどうか、または各セルがそのスタイルを維持するかどうかを指定します。

  • ザ・ border-spacing テーブルセル間に表示される幅を指定します。

  • ザ・ caption-sideキャプションは<caption>要素に表示されます。デフォルトでは、これらはドキュメントのテーブルの上にレンダリングされます。キャプション側プロパティを使用して、テーブルキャプションの配置を制御します。

  • ザ・ empty-cells セルが空の場合に境界線を表示するかどうかを指定します。

  • ザ・ table-layout ブラウザは、テーブルをレンダリングする前にテーブル全体をロードするのではなく、列の残りの部分で最初に検出されたwidthプロパティを使用して、テーブルのレイアウトを高速化できます。

次に、これらのプロパティの使用方法を例とともに示します。

border-collapseプロパティ

このプロパティには、2つの値を折りたたん分離することができます。次の例では、両方の値を使用しています-

<html>
   <head>
      <style type = "text/css">
         table.one {border-collapse:collapse;}
         table.two {border-collapse:separate;}
         
         td.a {
            border-style:dotted; 
            border-width:3px; 
            border-color:#000000; 
            padding: 10px;
         }
         td.b {
            border-style:solid; 
            border-width:3px; 
            border-color:#333333; 
            padding:10px;
         }
      </style>
   </head>

   <body>
      <table class = "one">
         <caption>Collapse Border Example</caption>
         <tr><td class = "a"> Cell A Collapse Example</td></tr>
         <tr><td class = "b"> Cell B Collapse Example</td></tr>
      </table>
      <br />
      
      <table class = "two">
         <caption>Separate Border Example</caption>
         <tr><td class = "a"> Cell A Separate Example</td></tr>
         <tr><td class = "b"> Cell B Separate Example</td></tr>
      </table>
   </body>
</html>

次の結果が得られます-

境界間隔プロパティ

border-spacingプロパティは、隣接するセルを分離する距離を指定します。ボーダーズ。1つまたは2つの値を取ることができます。これらは長さの単位である必要があります。

1つの値を指定すると、垂直方向と水平方向の両方の境界線に適用されます。または、2つの値を指定できます。この場合、最初の値は水平方向の間隔を示し、2番目の値は垂直方向の間隔を示します-

NOTE −残念ながら、このプロパティはNetscape7またはIE6では機能しません。

<style type="text/css">
   /* If you provide one value */
   table.example {border-spacing:10px;}
   /* This is how you can provide two values */
   table.example {border-spacing:10px; 15px;}
</style>

前の例を変更して、効果を見てみましょう-

<html>
   <head>
      <style type = "text/css">
         table.one {
            border-collapse:separate;
            width:400px;
            border-spacing:10px;
         }
         table.two {
            border-collapse:separate;
            width:400px;
            border-spacing:10px 50px;
         }
      </style>
   </head>

   <body>
   
      <table class = "one" border = "1">
         <caption>Separate Border Example with border-spacing</caption>
         <tr><td> Cell A Collapse Example</td></tr>
         <tr><td> Cell B Collapse Example</td></tr>
      </table>
      <br />
      
      <table class = "two" border = "1">
         <caption>Separate Border Example with border-spacing</caption>
         <tr><td> Cell A Separate Example</td></tr>
         <tr><td> Cell B Separate Example</td></tr>
      </table>
      
   </body>
</html>

次の結果が得られます-

キャプション側のプロパティ

caption-sideプロパティを使用すると、<caption>要素のコンテンツをテーブルとの関係で配置する場所を指定できます。次の表に、可能な値を示します。

このプロパティには、top、bottom、leftrightの4つの値のいずれかを指定できます。次の例では、各値を使用しています。

NOTE −これらのプロパティはIEブラウザでは機能しない場合があります。

<html>
   <head>
      <style type = "text/css">
         caption.top {caption-side:top}
         caption.bottom {caption-side:bottom}
         caption.left {caption-side:left}
         caption.right {caption-side:right}
      </style>
   </head>

   <body>
   
      <table style = "width:400px; border:1px solid black;">
         <caption class = "top">
            This caption will appear at the top
         </caption>
         <tr><td > Cell A</td></tr>
         <tr><td > Cell B</td></tr>
      </table>
      <br />
      
      <table style = "width:400px; border:1px solid black;">
         <caption class = "bottom">
            This caption will appear at the bottom
         </caption>
         <tr><td > Cell A</td></tr>
         <tr><td > Cell B</td></tr>
      </table>
      <br />
      
      <table style = "width:400px; border:1px solid black;">
         <caption class = "left">
            This caption will appear at the left
         </caption>
         <tr><td > Cell A</td></tr>
         <tr><td > Cell B</td></tr>
      </table>
      <br />
      
      <table style = "width:400px; border:1px solid black;">
         <caption class = "right">
            This caption will appear at the right
         </caption>
         <tr><td > Cell A</td></tr>
         <tr><td > Cell B</td></tr>
      </table>
      
   </body>
</html>

次の結果が得られます-

空のセルのプロパティ

empty-cellsプロパティは、コンテンツのないセルに境界線を表示するかどうかを示します。

このプロパティは、show、hideinheritの3つの値のいずれかを持つことができます。

<table>要素の空のセルの境界線を非表示にするために使用されるempty-cellsプロパティは次のとおりです。

<html>
   <head>
      <style type = "text/css">
         table.empty {
            width:350px;
            border-collapse:separate;
            empty-cells:hide;
         }
         td.empty {
            padding:5px;
            border-style:solid;
            border-width:1px;
            border-color:#999999;
         }
      </style>
   </head>

   <body>
   
      <table class = "empty">
         <tr>
            <th></th>
            <th>Title one</th>
            <th>Title two</th>
         </tr>
      
         <tr>
            <th>Row Title</th>
            <td class = "empty">value</td>
            <td class = "empty">value</td>
         </tr>
      
         <tr>
            <th>Row Title</th>
            <td class = "empty">value</td>
            <td class = "empty"></td>
         </tr>
      </table>
      
   </body>
</html>

次の結果が得られます-

テーブルレイアウトプロパティ

table-layoutプロパティは、ブラウザがテーブルをレンダリングまたはレイアウトする方法を制御するのに役立つはずです。

このプロパティには、fixed、autoinheritの3つの値のいずれかを指定できます。

次の例は、これらのプロパティの違いを示しています。

NOTE −このプロパティは多くのブラウザでサポートされていないため、このプロパティに依存しないでください。

<html>
   <head>
      <style type = "text/css">
         table.auto {
            table-layout: auto
         }
         table.fixed {
            table-layout: fixed
         }
      </style>
   </head>
   
   <body>
   
      <table class = "auto" border = "1" width = "100%">
         <tr>
            <td width = "20%">1000000000000000000000000000</td>
            <td width = "40%">10000000</td>
            <td width = "40%">100</td>
         </tr>
      </table>
      <br />
      
      <table class = "fixed" border = "1" width = "100%">
         <tr>
            <td width = "20%">1000000000000000000000000000</td>
            <td width = "40%">10000000</td>
            <td width = "40%">100</td>
         </tr>
      </table>
   
   </body>
</html>

次の結果が得られます-