• ベストアンサー
※ ChatGPTを利用し、要約された質問です(原文:css repeat-yを使ったデザインレイアウト)

CSS repeat-yを使ったデザインレイアウト

このQ&Aのポイント
  • CSS repeat-yを使用してデザインレイアウトを作成する方法についてご質問させていただきます。左カラムと右カラムでバックグラウンドを上下に分け、右カラムの高さに合わせて2つ目のバックグラウンドを下まで伸ばす方法を教えていただきたいです。
  • また、左カラムの内容が右カラムより少ない場合は、左カラムの高さに合わせるようにしています。画像をrepeat-yして表示させる方法についても不明点があります。flotすると表示がされないことがあるので、解決策をお知りになっている方のアドバイスをお願いします。
  • ご存知の方は、どうぞよろしくお願いいたします!

質問者が選んだベストアンサー

  • ベストアンサー
回答No.1

floatしている要素にではなく、floatしている要素の親要素に背景として指定すれば、長い方のボックスに高さが揃うように見えます。 floatする時はちゃんとクリアしてやらないと親要素に高さが反映されないので、可能ならclearプロパティで、もし無理なら親要素にoverflow:hidden;を指定しましょう。

hs07
質問者

お礼

ご回答ありがとうございます。 親要素にclearプロパティを指定すれば良いのですね。 試してみます!

その他の回答 (2)

  • ORUKA1951
  • ベストアンサー率45% (5062/11036)
回答No.3

例えばこんな感じ・・ <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html lang="ja"> <head> <meta http-equiv="content-type" content="text/html; charset=Shift_JIS"> <title>テスト</title> <meta name="author" content="ORUKA1951"> <meta http-equiv="Content-Style-Type" content="text/css"> <link rev="made" href="mailto:hoge@hoge.com" title="send a mail" > <style type="text/css"> <!-- div.Main{ position: relative; margin:0px 20px; width:auto; background-color:#aaaaaa; padding: 0px 200px; } div.Main div.index,div.Main div.note{ position:absolute; top:0px; width:180px; min-height:100%; } div.Main div.index{ left:0px; background-color: #aaffaa; } div.Main div.note{ right:0px; background-color: #aaaaff; } --> </style> <link rel="START" href="../index.html"> </head> <body> <h1>テスト</h1> <div class="Main"> <h2>見出し</h2> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <p>・・・・</p> <div class="index"> <ul> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <li><a href="./index.html">リンク</a></li> <ul> </div> <div class="note"> <h3>ノート</h3> <p>・・・・・・・・・・</p> <p>・・・・・・・・・・</p> <p>・・・・・・・・・・</p> </div> </body> </html>

  • ORUKA1951
  • ベストアンサー率45% (5062/11036)
回答No.2

どのようにHTMLやCSSが書かれているかを調べるには Firefoxiアドオンのfirebugを使うと一目瞭然です。 そのサイトの場合は、単純に親になるブロック要素の背景画像が繰り返されているだけですから、当然親要素の長さ分背景が続きます。  floatされている子要素の背景はありませんが、その中のブロック要素には背景や枠が指定されているため、親要素が早く終了しても背景はあります。  ただし、親要素の背景をこのfloatしている要素の長さに合わせるのはたいへん苦労します。  ただ、floatは安直にこのようなデザインができるので多用されますが、本来の目的とは少し違う使い方ですね。親要素内でfloatをさせる画像が現れたときにはややこしくなります。  親要素をrelativeなりabsoluteで指定して、このブロックはabsoluteで配置するほうが良いでしょう。

hs07
質問者

お礼

ご回答ありがとうございます。 firebugは便利ですね、活用します! >親要素をrelativeなりabsoluteで指定して、このブロックはabsoluteで配置するほうが良いでしょう。 上記のやり方でもグレー部分が内容によって伸びるのでしょうか? 不勉強ですみません。relative、absoluteはまったく使ったことがないのです…

関連するQ&A