ここで問題を確認できます: http://jsfiddle.net/6WuVz/7/
これは他のすべてのブラウザー (画像上部) では機能しますが、ie6 で表示すると (画像下部) 正しくラップされません。
注: 互換表示を使用して IE5 Quirks を選択すると、IE の新しいバージョンでこれを確認できます。
ここで問題を確認できます: http://jsfiddle.net/6WuVz/7/
これは他のすべてのブラウザー (画像上部) では機能しますが、ie6 で表示すると (画像下部) 正しくラップされません。
注: 互換表示を使用して IE5 Quirks を選択すると、IE の新しいバージョンでこれを確認できます。
私が知る限り、タイトルを保持する div には幅が設定されていません。したがって、IEは拡張するように指示しており、拡張すると、スペースがある場所で下に移動します。IE6 のみの幅を設定してみて、問題が解決するかどうかを確認してください。
さらに、IE6 にはいくつかの問題がありoverflow: hidden
ます。通常は と組み合わせて使用position: relative
されますが、似たようなものに遭遇する可能性があります。前の解決策が機能しない場合は、これを試すことができます。
編集- 明示的な幅を設定したくないので、他のいくつかのオプションを考えました:
clear: none
非浮動要素に明示的に設定span
代わりに要素を使用してください(はインラインですが、はブロックであるため、親の幅に拡張するべきではありません。あなたがしていることを考えると、おそらく を使用する方がセマンティックな意味があります)。div
span
div
span
div
て IE6 のフロートの幅を決定し、それに応じて非フロートのサイズを設定しますdiv
(ここでも、HTML で条件付きコメントを使用して IE6 のみをターゲットにすることができます)。IE6 には非標準のボックス モデルがあり、ブロック レベルの要素に対して、コンテンツを「シュリンク ラップ」するのではなく、コンテナーの全幅を拡張するように指示します。それらのコンテンツは、許可されている幅よりも大きく、float
プロパティはフロートされた要素をドキュメント フローから取り除きます (これが、 を にすると、フロートされたコンテンツの上に実行される理由overflow: hidden
ですoverflow: visible
)。新しいブラウザーは、基本的にプロパティの「更新された定義」(いわば) を持っていfloat
ます。これは、通常のドキュメント フローからそれを取り出すことに加えて、浮動要素の周りを兄弟コンテンツが流れるように指示します。さらに情報が必要な場合は、CSS-tricks に float に関する優れた記事があり、A List Apartも同様です。