IE9 ベータ版でレイアウトが上手くいかない。ので回避策。
[ 2011.02.12追記 ]
IE9 製品候補版では、この記事で取り上げた不具合は解消されたみたい。
この記事は最早、読む必要はありません。
IE9のベータ版を使ってみたのですが、スタイルシートを使っていろいろなレイアウトを試していたら、こんな事象に遭遇。
float:right; または float:left; を指定した要素の中で float:right; を指定した要素を並べると、お望み通りの表示にならないことがある。
こういうシチュエーションが一般的にどれくらいあるのかは判断しかねますが、以下のようなレイアウトを実現しようとしたときに起きる現象です。

スタイルシートは
div#container{
float:left;
}
div#right{
float:right;
border:solid 1px red;
}
div#left{
float:right;
border:solid 1px blue;
}
float:left;
}
div#right{
float:right;
border:solid 1px red;
}
div#left{
float:right;
border:solid 1px blue;
}
html(bodyの中身)は
<div id="container">
<div id="right">
〜 なかみ 〜
</div>
<div id="left">
〜 なかみ 〜
</div>
</div>
<div id="right">
〜 なかみ 〜
</div>
<div id="left">
〜 なかみ 〜
</div>
</div>
つまり「float:left; を指定したcontainerの中に、float:right; を指定したdiv要素をふたつ、横並びで表示させたい」という感じ。IE8、 Safari、 Firefox、 Chromeでは思い通りに表示されますが、IE9βだと、

う〜ん。縦に重なってしまう。
サンプルページを置いておきますので、いろいろなブラウザで見比べてください。
→ スタイルシート | float のテスト その1
ちなみに子要素の float 指定が left の場合は、IE9βでも狙ったとおりにキチンと表示されますね。
こいつの回避方法を3パターンほど思いついたのでメモメモ。
その1:親要素の幅を明示的に指定してやる → サンプル
div#container{
float:left;
width:400px;
}
float:left;
width:400px;
}
CSSの仕様書をがっつり読んだわけではないのでアレですが、「floatさせる要素の親要素の幅を明示すべき」なんていう決まりはあったかなぁ。containerに内包される要素のプロパティが float:right; じゃなくて float:left;のときは、狙った表示になるんだよなぁ。
その2:親要素の文書表示向きを弄ってやる。すなわち、親要素に direction: rtl; を指定してやる → サンプル
このとき、direction の設定は子要素に継承されてしまうので、子要素の文書表示方向を乱さないためには子要素に direction: ltr; を指定しなければなりません。
div#container{
float:left;
direction: rtl;
}
div#right{
float:right;
border:solid 1px red;
direction: ltr;
}
div#left{
float:right;
border:solid 1px blue;
direction: ltr;
}
float:left;
direction: rtl;
}
div#right{
float:right;
border:solid 1px red;
direction: ltr;
}
div#left{
float:right;
border:solid 1px blue;
direction: ltr;
}
その3:float:right; を使わずに、ぜんぶ float:left; でいく
とっても後ろ向きな解決策ですが、おそらく float:right; を float:left; に全て置き換える事は可能なはず。
いずれの方法に依っても、IE9β以外のブラウザでの表示には影響を与えません。
というわけで、IE8を含む殆どの現行ブラウザと異なる表示をしてしまうことがあるIE9βです。なんだかバグというか不具合っぽいなぁ。困るなぁ…と思いつつ、こいつはまだまだベータ版。正規版発表の暁には、なんとかなっていないものだろうか。
このブログ記事に対するトラックバックURL: http://freefielder.jp/ffmt/mtb.cgi/1135
検索
iTunes Store検索
tyz@freefielder.jp
カテゴリ
- Amazon Webサービス (4)
- Bossa Nova in Japan (8)
- Bossaカバー (19)
- ForeGround Music (299)
- Let's Note (10)
- Macintosh (48)
- PHP (37)
- Song Title Fetcher (1)
- Webアプリ (3)
- facebook (3)
- iPhone (65)
- via mobile
- どBossa (9)
- むかし福岡 (10)
- インターネットラジオ (7)
- クラフト (4)
- スタイルシート (5)
- スポーツ (1)
- ポ・リーグ (3)
- 今日の小室哲哉 (6)
- 嘘ネタ (2)
- 旅 (55)
- 日々 (112)
- 縦書き (30)
- 自転車 (24)
- 雑記 (233)
- 青空文庫 (8)
- 風物詩を撮る (1)
タグクラウド
- ホークス
- カバー曲
- 福岡
- iPhone
- CMソング
- 80's
- Masterpieces
- php
- bossa nova
- Macintosh
- パリーグ2008
- iPod
- 90's
- 映画
- 縦書き
- JavaScript
- 自転車
- パリーグ2009
- CSS3
- 最速でパリーグの優勝の行方を計算するページ
- パリーグ2010
- 珈琲
- 野球場
- 小ネタ
- 70's
- パリーグ2011
- ドラゴンズ
- カープ
- ファイターズ
- 台湾
- スタイルシート
- ヤフードーム
- ライオンズ
- itunes store
- 台湾プロ野球
- 笑ひ
- 新垣結衣
- マリーンズ
- UK
- 戦力外通告
- イーグルス
- WBC
- 通販
- 家電
- サッカー
- むかし福岡
- タイ
- バファローズ
- 羊毛とおはな
- Let's Note
- MacPorts
- 別府
- 迷惑アクセス
- 女優シンガー
- マカオ
- Bossaバブル
- NetRadio
- sotte bosse
- Xubuntu
- 助っ人
- 名古屋
- 椎名林檎
- 交流戦2008
- おみくじ
- オープン戦2008
- パリーグ2012
- ブログ
- ベイスターズ
- 煙草
- 著作権
- 香港
- 高橋幸宏
- 魚眼レンズ
- Movable Type
- OASIS
- Punk
- TVの音
- 原田知世
- 二軍
- うれすじキャッチャー
- アジアシリーズ
- スワローズ
- 統一ライオンズ
- Jazz
- John Lennon
- PowerBook G4
- Sex Pistols
- windows
- 小室哲哉
- 最速で2010年パリーグの優勝の行方を計算するページ
- オープン戦2009
- ドアラ
- パクチー
- Bruce Springsteen
- CentOS
- Coldplay
- 矢追純一
- 笑い
- 鳥居みゆき
- h2v.js
- IE9
- Windows
- 岡村ちゃん
- 星野JAPAN
- .htaccess
- 20世紀少年
- AWS
- コブクロ
- サンボマスター
- メタルバラード
- リモートデスクトップ
- レゲエ
- 稲尾和久
- 高品質CD
- HVT-BCT300
- Kids Bossa
- MacBook Air
- phpFreeChat
- RED HOT CHILLI PEPPERS
- THE BLUE HEARTS
- Tom Waits
- 平和台球場
- 海外旅行
- 佐野元春
- さくら
- イチロー
- イマココ。
- クレヨンしんちゃん
- ケツメイシ
- ポ・リーグ
- 王貞治
- 空気公団
- 菅野よう子
- 裸になって何が悪い
- 西鉄ライオンズ
- 鯨
- FON
- Guns N' Roses
- imageFlow
- JASRAC
- Joao Gilberto
- Michael Jackson
- Rickie-G
- TeN
- 冨田ラボ
- 午後の紅茶
- 原辰徳
- 原恵一
- 城島健司
- 小泉今日子
- 忌野清志郎
- 松山ケンイチ
- 板尾創路
- 浅野いにお
- 浅井健一
- 清原和博
- 中西健太
- 交流戦2009
- 交流戦2010
- 15秒ルール
- 2ちゃんねる
- かまやつひろし
- くるり
- さだまさし
- アスパラガス
- カオリーニョ藤原
- ジャイアンツ
- スタートレック
- スパム
- ソラニン
- タイガース
- ピアノポップ
- ファンキーモンキーベイビーズ
- ヘッドホン
- マクロレンズ
- BUMP OF CHICKEN
- 筒井康隆
- eastern youth
- enka bossa
- 都市伝説
- 野球英語
- 藤岡藤巻
- 雪
- 赤外線写真
- GPS
- Iggy Pop
- leonard cohen
- MeCab
- Monkey Majik
- My Chemical Romance
- NPB
- pupa
- Rage Against The Machine
- roots rock
- The Beatles
- UFO
- VNC
- WebDAV
- X JAPAN
- 刻印
- 加山雄三
- 坂本龍一
- 岡田准一
- 怪談
- 江頭2:50
- 世界のナベアツ
- 1941
- AKIRA
- Antony and The Johnsons
- おさかな天国
- さくらと一郎
- さよならポニーテール
- たむらぱん
- つじあやの
- つボイノリオ
- のあのわ
- ばっかじゃなかろか
- ほっともっと
- みかん
- アイドル
- アントニオ猪木
- イエティ
- ウミネコサウンズ
- オウンゴール
- カコイミク
- カルロス・リラ
- クリスマス
- サザンオールスターズ
- サーバー
- デジカメ
- ナメクジ
- ブルース・リー
- ヘチマ
- ベテランの味
- ペタンク
- ホタテ
- ポール・ポッツ
- マラドーナ
- ミッキー・ローク
- ユリオカ超特Q
- ライジング福岡
- レツゴー三匹
- ロバのパン
- bjリーグ
- Chrome
- 甘いもの
- 真島昌利
- 福岡市動植物園
- 税金
- 笹倉慎介
- David Bowie
- EXILE
- 酒
- 野茂英雄
- 頭から離れない
- 餃子
- 高田純次
- 高野寛
- 迷惑電話
- FDH
- Galaxie 500
- Green Day
- GX100
- GyaO
- HIDE
- JUJU
- Lou Reed
- mlb
- New Balance
- Nirvana
- Norah Jones
- Perfume
- plenty
- STF
- Tete
- The Rolling Stones
- UA
- UNICORN
- yumeiroecho
- 劇団ひとり
- 吉田えり
- 坂本真綾
- 夏への扉
- 大西ライオン
- 大分
- 尾道
- 川村かおり
- 布袋寅泰
- 新耳袋
- 旅
- 日野良一
- 映日紅はイチジクと読む
- 未映子
- 株
- 歯
- 清水ミチコ
- 湯川潮音
月別 アーカイブ
- 2012年
- 2011年
- 2010年
- 2009年
- 2008年
- 2007年
こちらの記事もどうぞ
- IE9 βのCSS3対応は微妙かもしれない。box-shadow。
- IE9 ベータ版でレイアウトが上手くいかない。ので回避策。その2。
- CSS3の3D transform、三次元回転やperspectiveの実装状況は?
- iOS版safariの「文字サイズ自動調整」がいやらしい。
- 縦書きスタイルシート、修正。
- Internet Explorer 9は普及しているのかね。
- スタイルシートだけで画像にさまざまな効果をプラスしてみる。その3。
- スタイルシートだけで画像にさまざまな効果をプラスしてみる。その2。
- スタイルシートだけで画像にさまざまな効果をプラスしてみる。その1。
- Internet Explorer 9 製品候補版が来た。CSS3はどうよ?
- [ 縦書き ] 行の文字数を揃える。
- スタイルシートを切り替えながらページの見栄えをチェック。
- JavaScriptでスタイルシートを弄る。
- 縦書きで横書き。
- 縦書き用スタイルシート、更新。

コメントする