CSS-レイアウト

HTMLテーブルに非常に慣れていて、HTMLテーブルを使用してページレイアウトを効率的に設計できることを願っています。しかし、CSSには、ドキュメント内の要素を配置するための多くのコントロールも用意されています。CSSは未来の波なので、ページレイアウトの目的でテーブルの代わりにCSSを学び、使用してみませんか?

次のリストは、両方のテクノロジーの長所と短所をいくつか集めたものです。

  • ほとんどのブラウザはテーブルをサポートしていますが、CSSサポートは徐々に採用されています。

  • ブラウザのウィンドウサイズが変更された場合、テーブルはより寛容になります。コンテンツをモーフィングし、それに応じて変更に対応するために折り返します。CSSの配置は正確で、かなり柔軟性がない傾向があります。

  • テーブルは、CSSルールよりも習得と操作がはるかに簡単です。

しかし、これらの議論はそれぞれ逆にすることができます-

  • CSSは、Webドキュメントの将来にとって極めて重要であり、ほとんどのブラウザーでサポートされます。

  • CSSはテーブルよりも正確であるため、ブラウザウィンドウに関係なく、ドキュメントを意図したとおりに表示できます。

  • ネストされたテーブルを追跡することは、非常に困難な場合があります。CSSルールは、よく整理され、読みやすく、簡単に変更できる傾向があります。

最後に、自分にとって意味のあるテクノロジーを使用し、知っていることやドキュメントを最良の方法で提示するものを使用することをお勧めします。

CSSは、テーブルの読み込みを大幅に高速化するtable-layoutプロパティも提供します。以下は例です-

<table style = "table-layout:fixed;width:600px;">
   <tr height = "30">
      <td width = "150">CSS table layout cell 1</td>
      <td width = "200">CSS table layout cell 2</td>
      <td width = "250">CSS table layout cell 3</td>
   </tr>
</table>

大きなテーブルでより多くの利点に気付くでしょう。従来のHTMLでは、ブラウザは最終的にテーブルをレンダリングする前にすべてのセルを計算する必要がありました。ただし、テーブルレイアウトアルゴリズムを固定に設定すると、テーブル全体をレンダリングする前に最初の行を確認するだけで済みます。これは、テーブルの列幅と行高を固定する必要があることを意味します。

サンプルの列レイアウト

CSSを使用して簡単な列レイアウトを作成する手順は次のとおりです-

ドキュメント全体の余白とパディングを次のように設定します-

<style style = "text/css">
   <!--
      body {
         margin:9px 9px 0 9px;
         padding:0;
         background:#FFF;
      }
   -->
</style>

ここで、黄色の列を定義し、後でこのルールを<div> −に添付します。

<style style = "text/css">
   <!--
      #level0 {
         background:#FC0;
      }
   -->
</style>

ここまでは、本文が黄色のドキュメントがあるので、level0 −内に別の区分を定義しましょう。

<style style = "text/css">
   <!--
      #level1 {
         margin-left:143px;
         padding-left:9px;
         background:#FFF;
      }
   -->
</style>

ここで、level1内にもう1つの分割をネストし、背景色だけを変更します-

<style style = "text/css">
   <!--
      #level2 {
         background:#FFF3AC;
      }
   -->
</style>

最後に、同じ手法を使用して、level2内にlevel3分割をネストし、右側の列の視覚的なレイアウトを取得します。

<style style = "text/css">
   <!--
      #level3 {
         margin-right:143px;
         padding-right:9px;
         background:#FFF;
      }
      #main {
         background:#CCC;
      }
   -->
</style>

次のようにソースコードを完成させます-

<style style = "text/css">
   body {
      margin:9px 9px 0 9px;
      padding:0;
      background:#FFF;
   }
	
   #level0 {background:#FC0;}
	
   #level1 {
      margin-left:143px;
      padding-left:9px;
      background:#FFF;
   }
	
   #level2 {background:#FFF3AC;}
	
   #level3 {
      margin-right:143px;
      padding-right:9px;
      background:#FFF;
   }
	
   #main {background:#CCC;}
</style>
<body>
   <div id = "level0">
      <div id = "level1">
         <div id = "level2">
            <div id = "level3">
               <div id = "main">
                  Final Content goes here...
               </div>
            </div>
         </div>
      </div>
   </div>
</body>

同様に、ページの上部に上部のナビゲーションバーまたは広告バーを追加できます。

次の結果が得られます-