首頁  >  文章  >  web前端  >  CSS haslayout 徹底了解

CSS haslayout 徹底了解

巴扎黑
巴扎黑原創
2017-06-28 10:23:141309瀏覽

要想更好的理解 css, 尤其是 IE 下對 css 的渲染,haslayout 是一個非常有必要徹底弄清楚的概念。大多IE下的顯示錯誤,就是源自於 haslayout。

什麼是 haslayout ?
  haslayout 是Windows Internet Explorer渲染引擎的一個內部組成部分。在InternetExplorer中,一個元素要麼自己對自身的內容進行計算大小和組織,要麼依賴父元素來計算尺寸和組織內容。為了調節這兩個不同的概念,渲染引擎採用了 hasLayout 的屬性,屬性值可以是true或false。當一個元素的 hasLayout屬性值為true時,我們說這個元素有一個佈局(layout)
  當一個元素有一個佈局時,它負責對自己和可能的子孫元素進行尺寸計算和定位。簡單來說,這意味著這個元素需要花更多的代價來維護自己和內在的內容,而不是依賴祖先元素來完成這些工作。因此,有些元素預設會有一個佈局。當我們說一個元素“擁有layout”或“得到layout”,或者說一個元素“has layout” 的時候,我們的意思是指它的微軟專有屬性 hasLayout 被設定為 true。一個「layout元素」可以是一個預設就擁有 layout 的元素或是一個透過設定某些 CSS 屬性來得到 layout的元素。如果某個HTML元素擁有 haslayout 屬性,那麼這個元素的 haslayout 的值一定只有 true,haslayout為唯讀屬性 一旦觸發,就不可逆轉。透過 IE Developer Toolbar 可以查看 IE 下 HTML元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout的元素,通常顯示為「haslayout = -1」。
  負責組織自身內容的元素將預設有一個佈局,主要包括以下元素(不完全列表):
  * body and html
  * table, tr, th, td
  * img
  * hr
  * input, button, file, select, textarea, fieldset
  * marquee
  * frameset, frame, iframe ##  新 預設有佈局,微軟給的主要原因是「效能和簡潔」。如果所有的元素都預設有佈局,會對效能和記憶體使用上產生有害的影響。
  如何激發 haslayout?
  大部分的 IE 顯示錯誤,都可以透過激發元素的 haslayout 屬性來修正。可以透過設定 css 尺寸屬性(width/height)等來激發元素的 haslayout,使其「擁有佈局」。如下所示,透過設定以下 css 屬性即可。
  * display: inline-block
  * height: (任何值除了auto)
  * float: (left 或right)
  * position: absolute
 〦 )
  *
writing-mode
: tb-rl   * zoom: (除normal 外任意值)   Internet Explorer 7 還有一些額外的屬性(不完全列表):
  *
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/Win 中內聯元素可以包含區塊級元素而少出問題,因為在別的瀏覽器中display: inline 就是內聯,不像IE/Win 一旦內聯元素擁有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
  IE6 及更低版本的雙空白邊浮動bug
  bug 修復: display:inline;
  IE5-6/win 的3 像素偏移 ##bug ## bug 修復: _height:1%;
  E6 的躲躲貓(peek-a-boo) bug
  bug 修復: _height:1%;

以上是CSS haslayout 徹底了解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:CSS layout入門下一篇:CSS layout入門