IE7 瀏覽器下面設定text-indent屬性變成margin屬性BUG,text-indentmargin
問題來源
今天做項目的時候發現了一個問題,在使用text-indent屬性對元素進行縮排是發現在360瀏覽器下發生了元素位移,跟margin-left的效果一樣,開啟f12發現3607.1瀏覽採用的ie7.0的文檔模式,果然在ie7裡面測試是一樣的結果
IE7下效果
其他瀏覽器下效果
之所以這樣是因為ie6、7瀏覽器不支援display屬性的inline-block值,你設定了也會忽視,而恰巧我的頁面中的元素就使用了display:inline-block屬性,但是在ie7看來就是inline ,但hiie6,7有haslayout屬性。就是說ie6,7中的inline元素有個特殊的情況,就是觸發了ie的hasLayout屬性以後就擁有了layout。此時inline元素的表現和標準瀏覽器裡面的inline-block元素基本相同。我們用ie的私人屬性zoom來觸發hasLayout,然後看看inline元素的表現。
display:inline-block; *display:inline; *zoom:1;
可以採用此種辦法觸發layout使其實現inline-block 當然也可以直接使用block屬性
display:inline-block;*display:block;
下面轉載了關於layout的介紹
什麼是 haslayout ?
“Layout”是一個 IE/Win 的私人概念,它決定了一個元素如何顯示以及約束其包含的內容、如何與其他元素互動和建立聯絡、如何響應和傳遞應用程式事件/使用者事件等,這有點類似於一個表單的概念。微軟的開發人員們認為盒狀元素(box-type elements)應該具有一個“屬性(property)”(這是物件導向編程中的一個概念),於是他們便使用了 layout , 也就是 hasLayout。hasLayout 其實既不是一個屬性更不是一個行為,而是 IE 這個渲染引擎代代繼承一貫擁有的一個渲染概念,在這個概念下渲染的元素將具有一種特性。實際上這種渲染特性在有些 HTML 元素中與身俱來,而在另外一些元素中也可以通過一些 CSS 屬性將其觸發為 true ,且一旦觸發將無法復原轉。
當我們說一個元素“擁有layout”或“得到layout”,或者說一個元素“has layout” 的時候,我們的意思是指它的微軟專有屬性 hasLayout 被設為了 true 。一個“layout元素”可以是一個預設就擁有 layout 的元素或者是一個通過設定某些 CSS 屬性得到 layout 的元素。而“無layout元素”,是指 hasLayout 未被觸發的元素,比如一個未設定寬高尺寸的乾淨 div 元素就可以做為一個 “無layout祖先”。給一個預設沒有 layout 的元素賦予 layout 的方法包括設定可觸發 hasLayout = true 的 CSS 屬性。參考預設 layout 元素以及這些屬性列表。沒有辦法設定 hasLayout = false , 除非把一開始那些觸發 hasLayout = true 的 CSS 屬性去除。IE Developer Toobar 可以即時檢查一個元素的當前樣式;如果 hasLayout 是 true ,那麼它的值顯示為 “-1”。 我們可以通過即時修改一個元素的屬性將“zoom(css)”設定為“1”來觸發 hasLayout 以便調試。另外可以用javascript擷取hasLayout的狀態,<script>alert(my.currentStyle.hasLayout);</script>,但是不可以設定。
另外一個需要注意的是“layout”會影響javascript編程。如果一個元素沒有“layout”,那麼clientWidth/clientHeight 總是返回0。這會讓一些指令碼新手感到困惑,而且這和 Mozilla 瀏覽器的處理方式也不一樣。不過我們可以利用這一點在 IE5.0 中檢測“layout”:如果 clientWidth 是零那麼這個元素就沒有 layout。
什麼情況下hasLayout會出現?
實際上一般情況都不會出現的,當然除了使用下面預設具有hasLayout的元素或使用特定樣式觸發hasLayout以外;它會帶來各種詭異表現,當你發現IE6 IE7出現了一些不可思議的問題,首先要檢查的就是是否是hasLayout在搗鬼;hasLayout只出現在IE7及更早版本中,IE8之後不存在hasLayout解析模式。
預設具有 haslayout 的元素(不完全列表)
* html, body
* table, tr, th, td
* img
* hr
* input, button, file, select, textarea, fieldset
* legend
* marquee
* frameset, frame, iframe
* objects, applets, embed
對於並非所有的元素都預設有布局,微軟給出的主要原因是“效能和簡潔”。如果所有的元素都預設有布局,會對效能和記憶體使用量上產生有害的影響。
如何激發 haslayout?
大部分的 IE 顯示錯誤,都可以通過激發元素的 haslayout 屬性來修正。可以通過設定 css 尺寸屬性(width/height)等來激發元素的 haslayout,使其“擁有布局”。如下所示,通過設定以下 css 屬性即可。
* display: inline-block
* height: (任何值除了auto) 通常用 _height:1%;解決IE6的問題,height:1%不會改變實際高度
* float: (left 或 right)
* position: absolute
* width: (任何值除了auto)
* writing-mode: tb-rl
* zoom: (除 normal 外任意值)
IE7 還有一些額外的屬性(不完全列表):
* min-height: (任意值)
* max-height: (除 none 外任意值)
* min-width: (任意值)
* max-width: (除 none 外任意值)
* overflow: (除 visible 外任意值)
* overflow-x: (除 visible 外任意值)
* overflow-y: (除 visible 外任意值)
* position: fixed
其中 overflow-x 和 overflow-y 是 css3 盒模型中的屬性,目前還未被瀏覽器廣泛支援。
對於內嵌元素(預設即為內聯的元素,如 span,或 display:inline; 的元素),width 和 height 只在 IE5.x 下和 IE6 或更新版本的 怪異 quirks 模式下觸發 hasLayout 。而對於IE6,如果瀏覽器運行於標準相容模式下,內嵌元素會忽略 width 或 height 屬性,所以設定 width 或 height不能在此種情況下令該元素具有 layout。
zoom 總是可以觸發 hasLayout,但是在 IE5.0 中不支援。
具有“layout” 的元素如果同時 display: inline ,那麼它的行為就和標準中所說的 inline-block很類似了:在段落中和普通文字一樣在水平方向連續排列,受 vertical-align 影響,並且大小可以根據內容自適應調整。這也可以解釋為什麼單單在 IE 中內嵌元素可以包含區塊層級元素而少出問題,因為在別的瀏覽器中display: inline 就是內聯,不像 IE 一旦內嵌元素擁有 layout 還會變成 inline-block。
haslayout 問題的調試與解決
當網頁在 IE 中有異常表現時,可以嘗試激發 haslayout 來看看是不是問題所在。常用的方法是給某元素 css 設定 zoom:1。使用 zoom:1 是因為大多數情況下,它能在不影響現有環境的條件下激發元素的 haslayout。而一旦問題消失,那基本上就可以判斷是haslayout 的原因。然後就可以通過設定相應的 css 屬性來對這個問題進行修正了。建議首先要考慮的是設定元素的width/height 屬性,其次再考慮其他屬性。
對 IE6 及更早版本來說,常用的方法被稱為霍莉破解(Holly hack),即設定這個元素的高度為 1%(height:1%;)。需要注意的是,當這個元素的 overflow 屬性被設定為 visible 時,這個方法就失效了。或者使用 IE的條件注釋。
對 IE7 來說,最好的方法時設定元素的最小高度為 0 (min-height:0;)。
haslayout 問題引起的常見 bug
E6 的躲躲貓(peek-a-boo) bug
bug 修複: _height:1%;
補充資料:
hasLayout的觸發條件:
- position: absolute(IE5+)
- float: left|right(IE5+)
- display: inline-block(IE5+)
- width: "auto"以外的任何值(IE5+; 對inline元素無效)
- height: "auto"以外的任何值(IE5+; 對inline元素無效)
- zoom: "normal"以外的任何值(IE5.5+; IE私人屬性)
- writing-mode: tb-rl(IE5+; IE私人屬性)
- overflow: hidden|scroll|auto(IE7; 此屬性在IE6及更早版本中不能應用在未觸發hasLayout的元素上)
- overflow-x|-y: hidden|scroll|auto(IE7; 此屬性在IE6及更早版本中不觸發hasLayout; 此屬性在CSS3中才獲支援)
- position: fixed(IE7)
- min-width: 任何值(IE7; 即使是0)
- max-width: "none"以外的任何值(IE7)
- min-height: 任何值(IE7)
- max-height: "none"以外的任何值 (IE7)
- position: fixed(IE7)
清除或重設hasLayout:
- position: static(IE5+)
- float: none(IE5+)
- display: "inline-block"以外的任何值(IE5+)
- width|height: "auto"(IE5+; 對inline元素無效)
- zoom: "normal"(IE5.5+; IE私人屬性)
- writing-mode: 從'tb-rl'到'lr-tb'(IE5+; IE私人屬性)
- max-width|max-height: "none"(IE7)
- overflow: visible(IE7)