- ベストアンサー
ADOBE DW 5.5 ヘッダとコンテンツの隙間
- 現在、独学でADOBE DREAM WEAVER CS 5.5でwebサイトを作成していますが、headerとcontentの間に10pixcelほどの隙間ができてしまいます。
- これを防ぐ方法はなにかありませんでしょうか?
- コードは下記となります。
- みんなの回答 (4)
- 専門家の回答
質問者が選んだベストアンサー
それなら、画像がベースラインになっているからだと思います。 http://www.htmq.com/style/vertical-align.shtml 初期値がbacelineです。のでアルファベットのgjpqは下に少し出る設定です。それらがなくても、画像を想定のベースラインそろえて配置します。下にピョコンと出ている想定分あいてしまって見えるわけです。 そこで下ぞろえを指定すれば、希望の隙間がない状態になると思います。 セレクタ{vertical-align:bottom;}
その他の回答 (3)
- ORUKA1951
- ベストアンサー率45% (5062/11036)
div内の要素のマージンが利いているだけです。 HTMLは文書構造だけを記述しましょう。 【引用】____________ここから DIV要素とSPAN要素は、id属性及び class属性と併用することで、文書に構造を付加するための一般機構を提供する。  ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ここまで[The global structure of an HTML document (ja)( http://www.asahi-net.or.jp/%7Esd5a-ucd/rec-html401j/struct/global.html#h-7.5.4 )]より どのような名称が良いかは、新しい要素 ( http://standards.mitsue.co.jp/resources/w3c/TR/html5-diff/#new-elements ) <body> <div class="header"> <h1><img src="a.png" width="1000" height="150" alt="タイトル"></h1> </div> <div class="section"> <h2>見出し</h2> <p>aaa</p> <p>aaa</p> <p>aaa</p> </div> <div class="footer"> <h2>文書情報</h2> </div> </body> ・・・ div.header,div.section,div.footer{margin:0 auto;width:100%;max-width:840px;} h1,h2,p{margin:0 auto;line-height:1.4em;}/* 上下のマージンを0 */ p{text-indent:1em;} この、margin:0 auto;でそのマージンは消えて、divドオシが密着するはずです。 同じ設定は、グループ化して記述する。 継承するプロパティは親ブロックに記述する。 HTMLは文書構造、スタイルシートはプレゼンテーションときちんと分けましょう。 ←構造とプレゼンテーションの分離 ( http://www.asahi-net.or.jp/%7Esd5a-ucd/rec-html401j/intro/intro.html#h-2.4.1 )
お礼
上記コードは質問のために少し簡素化したもので、実際に作っているwebサイトで、インスペクタモードで確認すると隙間はheaderに起因しているものでした。bacelineをbottomに変更したり、headerのサイズを写真のサイズに固定したら、隙間は消えました。 今回は自分のCSSとHTMLの認識不足を痛感させられました。リンクしていただいたサイトなども拝見させて頂きましたが、「なんとなくわかったような気がする」という状態で実際はちゃんと理解できていないのが現状です。実際にサイトを作りながら、勉強していきたい思います。今回は本当にありがとうございました。
- naokita
- ベストアンサー率57% (1008/1745)
旧IE非対応で良いなら: #content p:first-child{ margin-top:0;} style属性で1個目のPだけに直接書くなら: <div id="content"> <p style="margin-top:0;">aaa</p> #content { } に border-top を設置する方法もあるし、 #content p { } でmarginをリセットしてpaddingに変更するとか色々・・・
お礼
p:first-chaildというCSSは初めて見ました。ちょっと自分にはまだレベルが高いようです。。。すみません。質問させて頂いたコードではPタグのmarginが原因だったようです。しかし上記コードは質問のために少し簡素化したもので、実際に作っているwebサイトで、インスペクタモードで確認すると隙間はheaderに起因しているものでした。1000X150pixcelの写真が原因だと思い、写真を外しても隙間は消えませんでした。header idのmarginやpaddingもすべて0になっています。header内に起因した隙間だが、marginやpadding以外に隙間や間隔を空けるものがあるかどうかわからず、行き詰ってしまっています。もう少し自分でいろいろ触ってみます。何かお気づきのことがありましたら、助言いただけるとうれしいです。ありがとうございました。
- DrFell
- ベストアンサー率55% (305/551)
headerとcontentの間に10pixcelほどの…… ではなく、おそらくcontent内部の問題かと思います。 #content p{margin:0;} を加えてみてはいかがでしょうか? 今回のような問題の場合、構造を視覚的に表示すると、原因となっている場所が判明しやすいです。アウトラインを示す表示モードにブラウザを変えたり、cssで一時的に*{border 1px solid red}などとし、問題の空間がどこの領域に属するのかを見て見られてはいかがでしょうか? その上で今回の場合、content内と判明すれば、その最初の中身と容易に想像がつくと思います。
お礼
回答ありがとうございます。今実際にためしてみました。確かに今回こちらに書いたコードはPタグが原因だったようです。こちらに書いたコードは少し簡素化したものなのですが、実際に今自分で作っているサイトはヘッダがあり、ナビゲーションバーがあり、その下にコンテンツがある状態です(1カラム)。それで、ヘッダの写真にアウトラインをつけてみたら、そのheader内の写真下のところに、隙間ができていました。写真が原因だと思い、写真を外しても隙間は消えませんでした。インスペクタモードで確認をしても、やはり、別のBOXのpaddingやmarginが影響している状態ではありませんでした。写真の大きさは1000 X 150pixcelで間違いないのですが。。。 もう少し自分でがんばってみます。何かお気づきの点がありましたら、教えて頂けるとうれしいです。アウトラインなどでの確認の方法はとても参考になりました。ありがとうございました。
お礼
vertical-alignをbottomに変更したら、直りました!!またこの方法以外にheaderのサイズが指定してなかったので指定してみると、その方法でも直りました!!bacelineについて画像であってもgjpqがあることを想定して一応その分下に余白を作っておくということでしょうか??HTMLとCSSの組み合わせで解決の方法が何通りもあり、単純な自分としてはこういうことが混乱のもとになってしまいます。実はまだ他にもいろいろお伺いしたいことがあるのですが、今自分で試行錯誤しています。またどうしてもわからないことがあれば、お伺いをしたいと思います。勉強になりました!本当にありがとうございました!!