2011-11-05 22 views
0

自分自身の責任でなければならないことは分かっているが、私が間違っていたことは見ていない。 ChromeとFireFoxで予想どおりに表示されます。 IE9で失敗します。私はW3C CSSバリデーターを使用し、それはきれいに戻った。初心者のCSSトラブル - IEでは表示されるが、ChromeやFireFoxでは表示されない

すべて私は、同じ行にテキスト(左に水平に整列、垂直に一番下に整列)とイメージ(バナーの追加)を入れたいです。

<div id="header"> 
    <span id="logo">MyCoolLogoText!</span> 
    <img id="ad1" src="banner.jpg">  
</div> 

私はこれで苦労してきたように私のCSSが長く得ているが、それは

現在

#logo { 
width:507px; 
height:65px; 
display:inline; 
float:left; 
text-align:left;  
vertical-align: text-bottom; 
color:white; 
margin:0; 
padding:0; 
background-color:rgb(77,00,00); 
} 

#ad1 { 
float:left; 
display:inline; 
width:468px; 
height:65px; 
margin:0; 
padding:0; 
} 
#header 
{ 
    width:975px;  
    height:75px;  
    margin:0; 
    padding:0;  
} 
であるInternet Explorerが最初の行にスパンを配置し、次の行の画像です。どちらかの幅を小さくすると、どちらも最上行に表示されます。私はIEがある種のマージンやパディングを追加していると仮定しています。しかし、私はそれを言わないようにしました。

ご協力いただければ幸いです。

編集:私はそれがmarginまたはpaddingを追加するので、あなたが持っていることを確認することができ#ヘッダー

+0

#headerのスタイルは何ですか?それはラップを引き起こすコンテナのパディングのように聞こえる。また、表示:インラインと浮動小数点は一種の矛盾です(浮動小数点が優先されます)。 floatはそれをブロック要素にしますが、それはあなたが幅を変更できる唯一の理由です。 – mqsoh

答えて

1

のためのスタイリング情報を追加しました:

body { 
    margin: 0; 
    padding: 0; 
} 

しかし、それはちょうどあなたのウィンドウ幅かもしれません。オブジェクトを浮動させ、幅を固定しているので、ブラウザーウィンドウの幅を縮小するだけで、どのブラウザーでもIE9で見られるのと同じ効果を得ることができます。それが浮動小数点の仕組みの性質です。それを解決するには、この(私はあなたの現在のマージン、パディング、ボーダーの設定で何を参照してくださいオフに基づいて)実行します。

#header { 
    min-width: 975px; /* the width of your two floated elements */ 
} 

をあなたはmin-widthの代わりにwidthを使用することができます。

編集:さて、あなたはヘッダーの幅を持っていました。 imgタグの構文が正しくないことがわかりました。 <img id="ad1" src="banner.jpg">がありますが、閉じスラッシュ<img id="ad1" src="banner.jpg" />がありません。私はそれが問題だとは思っていませんが、一方で、ブラウザは無効なコードで面白いことをすることができます。

+0

_ _が自己閉鎖する必要があるかどうかは、doctypeによって異なります。あなたはXHTMLで間違いなく、普通のHTML _ _は空の要素であり、閉じスラッシュは必要ありません。 –

+0

良い点。私は以前の標準について忘れてしまったXHTMLのコーディングに慣れています。 – ScottS

1

#ad1をインラインブロックとして表示し、右に浮かべてみてください。また、泡を囲むようにしたい場合は、#headerに隠されたオーバーフローを叩きます(オーバーフローさせる必要がない限り)。

関連する問題