2012-03-17 13 views
7

divを画面の下端ではなくページの下端に合わせたいとします。私がこれをするとき:画面の下端ではなく、ページの下端を合わせる方法

#contact-block{ 
position: absolute; 
    bottom: 0; left: 0; 
} 

の場合、divは画面の下部に配置されます。私のページが長いと、私は下にスクロールする必要があり、下部にあったはずのdivは、中間のどこかに浮かぶ。

これには単純な解決策があるかもしれませんが、私はそれを見ていません。 enter image description here

赤のdivが接触div要素である:

<div id="left"> 
<div id="submenu"> <span class="menutitle">Services</span> 
    <ul> 
    </ul> 
</div> 

<div id="contact-block"> 
<span class="contacttitle">Contact</span></div> 
</div> 
<div id="content"> 
</div> 

は、私も私が何を意味するか説明するために少し画像を追加しました:

は、ここに私のHTMLです。

編集: jQueryとCSSで解決策を見つけました。これは最善の解決策ではないかもしれませんが、ちょっと、うまくいきます。

のjQuery:

var offset= $(document).height()-$("#contact-block").height()- $("#footer").height()-60; 
$("#contact-block").css("top", offset); 
$("#contact-block").css("left", $("#wrapper").position().left); 

CSS:

#contact-block { 
position : absolute; 
width:216px; 
height:100px; 
background:url(../img/contact-bg.jpg) repeat-x #5c5c5c; 
} 
+1

だから、ちょうどそれをHTMLの一番下に置くのはなぜですか? – SergeS

+1

htmlを投稿できますか? –

+0

これは、メニューの下にあるコンテンツの左側のブロックで、メニューの同じdivにあります。メニューは上部に揃えられ、接点ブロックは下部に揃えられます。 – samn

答えて

1

あなたabsolute配置要素の位置がデフォルトにあるstaticを(配置されていない最初の祖先要素に依存するので、明示的にrelative(またはabsolute)に設定する必要があります)。

したがって、同封の#leftコンテナには100%ドキュメントハイトとposition:relativeがあり、すべてがうまくいきます。

0

等しい高さの列:http://css-tricks.com/fluid-width-equal-height-columns/を見てください。これは十分かもしれ単純な場合には

(私はちょうどbody、あなたの#left列は左浮遊しcontent列が右浮かぶと他のラッパー要素が存在しないと仮定しています):

body { 
    position:relative; 
} 

#contact-block { 
    position:absolute; 
    bottom:0; 
    left:0; 
} 

することを忘れないでくださいbodyの末尾に明確な要素<div style="clear:both"></div>を追加します。

2

divを絶対配置することができます。このテクニックには、私が好きではない#wrapper要素が必要ですが、ねえ、あなたはすべきことがあります。

この例では、レイアウトにのみ必要であり、もはや必要でないため、#leftdivを完全に削除しました。

HTML:

<div id="wrapper"> 
    <div id="submenu">This is services</div> 
    <div id="contact-block">This is contact</div> 
    <div id="content">This is content</div> 
</div>​ 

CSS:

#wrapper { 
    position: relative; 
    width: 960px; 
} 

#submenu { 
    position: absolute; 
    left: 0; 
    top: 0; 
    width: 320px; 
    height: 320px; 
} 

#contact-block { 
    position: absolute; 
    left: 0; 
    bottom: 0; 
    width: 320px; 
    height: 160px; 
} 

#content { 
    position: relative; 
    left: 320px; 
    right: 0; 
    top: 0; 
    width: 640px; 
    height: 640px; 
} 

//#content position is relative for the #wrapper to stretch. 
//The left property is equal to the width of the #submenu or #contact-block element 

この技術の良い点は、それがあなたのクリーナーHTMLを与えることです。必要が生じた場合、あなたのバージョンのモバイル版を作る方が簡単になると思います。

The jsfiddle

追加の思考は: #wrapper要素を簡単にあなたの賛成でセマンティックHTMLに向けた大きな一歩であるbody要素を、除去することができました。 Check this out!

+0

私はラッパー要素としてbodyを使用しようとしていましたが、内容がウィンドウよりも大きかったために私が気付いていなかったのは私がposition:relativeをボディ上に置いたか、デフォルトで絶対配置された要素がウィンドウに対して相対的でした! – Mark

0

赤いdivを右の長いdivの内側と最後に配置することをおすすめします。次に、position: relativeと赤のdivの左の余白をマイナスして左に押し出します。このように、右のdivが拡大すると、赤いdivは常にその下にとどまります。

関連する問題