亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

徹底弄清楚haslayout概念

2024-07-11 09:04:21
字體:
來源:轉載
供稿:網友

武林網(www.49028c.com)文章簡介:haslayout 是Windows Internet Explorer渲染引擎的一個內部組成部分。

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

什么是 haslayout ?

haslayout 是Windows Internet Explorer渲染引擎的一個內部組成部分。在Internet Explorer中,一個元素要么自己對自身的內容進行計算大小和組織,要么依賴于父元素來計算尺寸和組織內容。為了調節這兩個不同的概念,渲染引擎采用了 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
* objects, applets, embed

對于并非所有的元素都默認有布局,微軟給出的主要原因是“性能和簡潔”。如果所有的元素都默認有布局,會對性能和內存使用上產生有害的影響。

如何激發 haslayout?

大部分的 IE 顯示錯誤,都可以通過激發元素的 haslayout 屬性來修正??梢酝ㄟ^設置 css 尺寸屬性(width/height)等來激發元素的 haslayout,使其“擁有布局”。如下所示,通過設置以下 css 屬性即可。

* display: inline-block
* height: (任何值除了auto)
* float: (left 或 right)
* position: absolute
* width: (任何值除了auto)
* 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 問題引起的常見 bugIE6 及更低版本的雙空白邊浮動 bug

    bug 修復: display:inline;

    IE5-6/win 的 3 像素偏移 bug

    bug 修復: _height:1%;

    E6 的躲躲貓(peek-a-boo) bug

    bug 修復: _height:1%;

    糖伴西紅柿說,這篇文章不是原創,是網上資源的匯總,加上自己理解的綜合。可能還不是很全面,還需要再進一步細化。

    發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
    国产91精品久久久久久久| 亚洲免费中文字幕| 欧美一级电影在线| 日韩风俗一区 二区| 日韩高清a**址| 在线视频日本亚洲性| 亚洲а∨天堂久久精品9966| 国产97在线|亚洲| 九九综合九九综合| 欧美怡红院视频一区二区三区| 日本国产精品视频| 国产精品一区av| 中文字幕日韩av综合精品| 欧美日韩精品国产| 欧美大片免费观看| 国产成人小视频在线观看| 国产va免费精品高清在线| 成人激情av在线| 欧美性感美女h网站在线观看免费| 91中文精品字幕在线视频| 国产精品久久一区| 欧美性xxxxx极品娇小| 亚洲qvod图片区电影| 欧美极品欧美精品欧美视频| 精品国产一区二区三区久久狼黑人| 久久久999国产精品| 欧美一区二区影院| 91在线直播亚洲| 国产成人精品电影| 91精品久久久久久久久久久久久| 欧美激情亚洲自拍| 久久久亚洲福利精品午夜| 国产欧美日韩亚洲精品| 欧美性xxxx极品hd欧美风情| 中文字幕亚洲欧美日韩在线不卡| 欧美日韩亚洲精品内裤| 精品久久中文字幕久久av| 国内精品中文字幕| 国产精品高潮视频| 麻豆国产va免费精品高清在线| 国产精品视频自拍| 亚洲欧美另类在线观看| 国产又爽又黄的激情精品视频| 亚洲天堂男人天堂| 国产欧美精品xxxx另类| 成人激情黄色网| 亚洲男人第一av网站| 神马久久桃色视频| 成人黄色大片在线免费观看| 亚洲国产成人精品电影| 欧美国产在线视频| 日韩精品极品视频| 日韩二区三区在线| 成人美女av在线直播| 中文欧美在线视频| 国产精品久久久久久久久借妻| 日韩高清a**址| 亚洲综合在线小说| 欧美激情精品久久久久久久变态| 亚洲欧洲美洲在线综合| 91精品国产91久久久久| 国产一区二区三区在线观看网站| 伊人成人开心激情综合网| 国产亚洲精品美女久久久久| 久久99精品久久久久久琪琪| 亚洲精品网址在线观看| 国产精品成人一区二区| 日韩中文理论片| 欧美电影在线播放| 日本久久久久亚洲中字幕| 国产999精品久久久影片官网| 亚洲欧美日韩第一区| 91热精品视频| 亚洲最大的av网站| 亚洲成人在线网| 日韩欧美第一页| 亚洲成人精品久久| 欧美激情中文字幕乱码免费| 亚洲国产精品久久久久秋霞不卡| 久久久久久国产| 国产精品第8页| 日韩在线免费高清视频| 97精品免费视频| 国内精品中文字幕| 国产成人亚洲综合91| 亚洲天堂男人的天堂| 欧美最近摘花xxxx摘花| 亚洲电影中文字幕| 日韩av黄色在线观看| 国产欧美日韩亚洲精品| 欧美日韩国产综合视频在线观看中文| 亚洲欧美福利视频| 色午夜这里只有精品| 91精品国产自产在线观看永久| 91免费的视频在线播放| 影音先锋日韩有码| 日韩成人网免费视频| 亚洲a成v人在线观看| 国产精品一二三在线| 精品国内产的精品视频在线观看| 欧美激情亚洲国产| 欧美日韩在线观看视频小说| 国产成人在线一区二区| 国产欧美日韩免费看aⅴ视频| 亚洲视频免费一区| 成人激情视频在线播放| 国产精品一二三在线| 欧美精品国产精品日韩精品| 欧美一级大胆视频| 日韩成人网免费视频| 亚洲欧美中文日韩v在线观看| 欧美日韩亚洲系列| 精品人伦一区二区三区蜜桃网站| 最近2019中文免费高清视频观看www99| 国产精品电影久久久久电影网| 久久久久久91香蕉国产| 国产成人在线播放| 国产国语刺激对白av不卡| 91精品中文在线| 国产美女精品视频免费观看| 日韩a**中文字幕| 久久艹在线视频| 亚洲国产精品国自产拍av秋霞| 精品日韩视频在线观看| 久久精品这里热有精品| 亚洲精品之草原avav久久| 国产精品视频在线播放| 亚洲一区二区日本| 欧美影院在线播放| 国产精品久久久久秋霞鲁丝| 一区二区三区回区在观看免费视频| 久久久久北条麻妃免费看| 97婷婷涩涩精品一区| 亚洲一级一级97网| 精品美女久久久久久免费| 亚洲欧美日韩国产中文专区| 国产精品久久久久久久久久ktv| 欧美精品激情blacked18| 51久久精品夜色国产麻豆| 日韩av成人在线观看| 亚洲精品免费网站| www.亚洲人.com| 亚洲乱码av中文一区二区| 亚洲毛片在线免费观看| 日本一区二区三区四区视频| 午夜免费日韩视频| 欧美激情在线有限公司| 精品欧美激情精品一区| 亚洲奶大毛多的老太婆| 国产精品欧美一区二区三区奶水| 久久久久久久久久国产| 欧美午夜无遮挡| 欧美视频精品一区| 精品成人av一区| 亚洲国产精品99久久| 国产精品综合久久久| 亚洲国内精品在线| 国产欧美最新羞羞视频在线观看| 日本一区二三区好的精华液| 久久免费国产精品1| 国产不卡一区二区在线播放| 久久综合久久八八| 日韩成人中文电影| xxxx性欧美|