IE對(duì)CSS的渲染引擎hasLayout_Div+CSS教程
教程Tag:暫無Tag,歡迎添加,賺取U幣!
haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在InternetExplorer中,一個(gè)元素要么自己對(duì)自身的內(nèi)容進(jìn)行計(jì)算大小和組織,要么依賴于父元素來計(jì)算尺寸和組織內(nèi)容。為了調(diào)節(jié)這兩個(gè)不同的概念,渲染引擎采用了 hasLayout 的屬性,屬性值可以為true或false。當(dāng)一個(gè)元素的 hasLayout屬性值為true時(shí),我們說這個(gè)元素有一個(gè)布局(layout)
要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。
當(dāng)一個(gè)元素有一個(gè)布局時(shí),它負(fù)責(zé)對(duì)自己和可能的子孫元素進(jìn)行尺寸計(jì)算和定位。簡(jiǎn)單來說,這意味著這個(gè)元素需要花更多的代價(jià)來維護(hù)自身和里面的內(nèi)容,而不是依賴于祖先元素來完成這些工作。因此,一些元素默認(rèn)會(huì)有一個(gè)布局。當(dāng)我們說一個(gè)元素“擁有l(wèi)ayout”或“得到layout”,或者說一個(gè)元素“has layout” 的時(shí)候,我們的意思是指它的微軟專有屬性 hasLayout 被設(shè)為了 true。一個(gè)“layout元素”可以是一個(gè)默認(rèn)就擁有 layout 的元素或者是一個(gè)通過設(shè)置某些 CSS 屬性得到 layout的元素。如果某個(gè)HTML元素?fù)碛?haslayout 屬性,那么這個(gè)元素的 haslayout 的值一定只有 true,haslayout為只讀屬性 一旦被觸發(fā),就不可逆轉(zhuǎn)。通過 IE Developer Toolbar 可以查看 IE 下 HTML元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout的元素,通常顯示為“haslayout = -1”。
負(fù)責(zé)組織自身內(nèi)容的元素將默認(rèn)有一個(gè)布局,主要包括以下元素(不完全列表):
* body and html
* table, tr, th, td
* img
* hr
* input, button, file, select, textarea, fieldset
* marquee
* frameset, frame, iframe
* objects, applets, embed
對(duì)于并非所有的元素都默認(rèn)有布局,微軟給出的主要原因是“性能和簡(jiǎn)潔”。如果所有的元素都默認(rèn)有布局,會(huì)對(duì)性能和內(nèi)存使用上產(chǎn)生有害的影響。
如何激發(fā) haslayout?
大部分的 IE 顯示錯(cuò)誤,都可以通過激發(fā)元素的 haslayout 屬性來修正。可以通過設(shè)置 css 尺寸屬性(width/height)等來激發(fā)元素的 haslayout,使其“擁有布局”。如下所示,通過設(shè)置以下 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 盒模型中的屬性,目前還未被瀏覽器廣泛支持。
對(duì)于內(nèi)聯(lián)元素(默認(rèn)即為內(nèi)聯(lián)的元素,如 span,或 display:inline; 的元素),
width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下觸發(fā) hasLayout 。而對(duì)于IE6,如果瀏覽器運(yùn)行于標(biāo)準(zhǔn)兼容模式下,內(nèi)聯(lián)元素會(huì)忽略 width 或 height 屬性,所以設(shè)置 width 或 height不能在此種情況下令該元素具有 layout。
zoom 總是可以觸發(fā) hasLayout,但是在 IE5.0 中不支持。
具有“layout” 的元素如果同時(shí) display: inline ,那么它的行為就和標(biāo)準(zhǔn)中所說的 inline-block很類似了:在段落中和普通文字一樣在水平方向和連續(xù)排列,受 vertical-align影響,并且大小可以根據(jù)內(nèi)容自適應(yīng)調(diào)整。這也可以解釋為什么單單在 IE/Win 中內(nèi)聯(lián)元素可以包含塊級(jí)元素而少出問題,因?yàn)樵趧e的瀏覽器中display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會(huì)變成 inline-block。
haslayout 問題的調(diào)試與解決
當(dāng)網(wǎng)頁(yè)在 IE 中有異常表現(xiàn)時(shí),可以嘗試激發(fā) haslayout 來看看是不是問題所在。常用的方法是給某元素 css 設(shè)定 zoom:1。使用 zoom:1 是因?yàn)榇蠖鄶?shù)情況下,它能在不影響現(xiàn)有環(huán)境的條件下激發(fā)元素的 haslayout。而一旦問題消失,那基本上就可以判斷是haslayout 的原因。然后就可以通過設(shè)定相應(yīng)的 css 屬性來對(duì)這個(gè)問題進(jìn)行修正了。建議首先要考慮的是設(shè)定元素的width/height 屬性,其次再考慮其他屬性。
對(duì) IE6 及更早版本來說,常用的方法被稱為霍莉破解(Holly hack),即設(shè)定這個(gè)元素的高度為 1%(height:1%;)。需要注意的是,當(dāng)這個(gè)元素的 overflow 屬性被設(shè)置為 visible 時(shí),這個(gè)方法就失效了�;蛘呤褂� IE的條件注釋。
對(duì) IE7 來說,最好的方法時(shí)設(shè)置元素的最小高度為 0 (min-height:0;)。
haslayout 問題引起的常見 bug
IE6 及更低版本的雙空白邊浮動(dòng) bug
bug 修復(fù): display:inline;
IE5-6/win 的 3 像素偏移 bug
bug 修復(fù): _height:1%;
E6 的躲躲貓(peek-a-boo) bug
bug 修復(fù): _height:1%;
要想更好的理解 css, 尤其是 IE 下對(duì) css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。
當(dāng)一個(gè)元素有一個(gè)布局時(shí),它負(fù)責(zé)對(duì)自己和可能的子孫元素進(jìn)行尺寸計(jì)算和定位。簡(jiǎn)單來說,這意味著這個(gè)元素需要花更多的代價(jià)來維護(hù)自身和里面的內(nèi)容,而不是依賴于祖先元素來完成這些工作。因此,一些元素默認(rèn)會(huì)有一個(gè)布局。當(dāng)我們說一個(gè)元素“擁有l(wèi)ayout”或“得到layout”,或者說一個(gè)元素“has layout” 的時(shí)候,我們的意思是指它的微軟專有屬性 hasLayout 被設(shè)為了 true。一個(gè)“layout元素”可以是一個(gè)默認(rèn)就擁有 layout 的元素或者是一個(gè)通過設(shè)置某些 CSS 屬性得到 layout的元素。如果某個(gè)HTML元素?fù)碛?haslayout 屬性,那么這個(gè)元素的 haslayout 的值一定只有 true,haslayout為只讀屬性 一旦被觸發(fā),就不可逆轉(zhuǎn)。通過 IE Developer Toolbar 可以查看 IE 下 HTML元素是否擁有haslayout,在 IE Developer Toolbar 下,擁有 haslayout的元素,通常顯示為“haslayout = -1”。
負(fù)責(zé)組織自身內(nèi)容的元素將默認(rèn)有一個(gè)布局,主要包括以下元素(不完全列表):
* body and html
* table, tr, th, td
* img
* hr
* input, button, file, select, textarea, fieldset
* marquee
* frameset, frame, iframe
* objects, applets, embed
對(duì)于并非所有的元素都默認(rèn)有布局,微軟給出的主要原因是“性能和簡(jiǎn)潔”。如果所有的元素都默認(rèn)有布局,會(huì)對(duì)性能和內(nèi)存使用上產(chǎn)生有害的影響。
如何激發(fā) haslayout?
大部分的 IE 顯示錯(cuò)誤,都可以通過激發(fā)元素的 haslayout 屬性來修正。可以通過設(shè)置 css 尺寸屬性(width/height)等來激發(fā)元素的 haslayout,使其“擁有布局”。如下所示,通過設(shè)置以下 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 盒模型中的屬性,目前還未被瀏覽器廣泛支持。
對(duì)于內(nèi)聯(lián)元素(默認(rèn)即為內(nèi)聯(lián)的元素,如 span,或 display:inline; 的元素),
width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下觸發(fā) hasLayout 。而對(duì)于IE6,如果瀏覽器運(yùn)行于標(biāo)準(zhǔn)兼容模式下,內(nèi)聯(lián)元素會(huì)忽略 width 或 height 屬性,所以設(shè)置 width 或 height不能在此種情況下令該元素具有 layout。
zoom 總是可以觸發(fā) hasLayout,但是在 IE5.0 中不支持。
具有“layout” 的元素如果同時(shí) display: inline ,那么它的行為就和標(biāo)準(zhǔn)中所說的 inline-block很類似了:在段落中和普通文字一樣在水平方向和連續(xù)排列,受 vertical-align影響,并且大小可以根據(jù)內(nèi)容自適應(yīng)調(diào)整。這也可以解釋為什么單單在 IE/Win 中內(nèi)聯(lián)元素可以包含塊級(jí)元素而少出問題,因?yàn)樵趧e的瀏覽器中display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會(huì)變成 inline-block。
haslayout 問題的調(diào)試與解決
當(dāng)網(wǎng)頁(yè)在 IE 中有異常表現(xiàn)時(shí),可以嘗試激發(fā) haslayout 來看看是不是問題所在。常用的方法是給某元素 css 設(shè)定 zoom:1。使用 zoom:1 是因?yàn)榇蠖鄶?shù)情況下,它能在不影響現(xiàn)有環(huán)境的條件下激發(fā)元素的 haslayout。而一旦問題消失,那基本上就可以判斷是haslayout 的原因。然后就可以通過設(shè)定相應(yīng)的 css 屬性來對(duì)這個(gè)問題進(jìn)行修正了。建議首先要考慮的是設(shè)定元素的width/height 屬性,其次再考慮其他屬性。
對(duì) IE6 及更早版本來說,常用的方法被稱為霍莉破解(Holly hack),即設(shè)定這個(gè)元素的高度為 1%(height:1%;)。需要注意的是,當(dāng)這個(gè)元素的 overflow 屬性被設(shè)置為 visible 時(shí),這個(gè)方法就失效了�;蛘呤褂� IE的條件注釋。
對(duì) IE7 來說,最好的方法時(shí)設(shè)置元素的最小高度為 0 (min-height:0;)。
haslayout 問題引起的常見 bug
IE6 及更低版本的雙空白邊浮動(dòng) bug
bug 修復(fù): display:inline;
IE5-6/win 的 3 像素偏移 bug
bug 修復(fù): _height:1%;
E6 的躲躲貓(peek-a-boo) bug
bug 修復(fù): _height:1%;
相關(guān)Div+CSS教程:
- DIV+CSS設(shè)計(jì)的誤區(qū)
- CSS基礎(chǔ):常用CSS英文字體介紹
- IE6和IE7中border邊框斷線現(xiàn)象
- border:none;與border:0;的有什么不同?
- div+css下js對(duì)聯(lián)廣告不隨屏幕滾動(dòng)的解決方法
- HTML元素的ID和Name屬性的區(qū)別
- divcss教程:深入了解css的行高Line Height屬性
- CSS文檔流,塊級(jí)元素和內(nèi)聯(lián)元素
- 5個(gè)你該知道的CSS3新技術(shù)
- 用正則表達(dá)式替換a標(biāo)記href值
- 30個(gè)優(yōu)秀的CSS導(dǎo)航和按鈕設(shè)計(jì)教程
- css中px和em有什么區(qū)別
Div+CSS教程Rss訂閱Div+Css教程搜索
Div+CSS教程推薦
- DivCSS教程:DTD(文檔類型)影響margin實(shí)現(xiàn)居中的分析
- CSS文件是鏈接還是應(yīng)該嵌入?
- divcss網(wǎng)站布局的八個(gè)小技巧
- 如何用css控制一個(gè)容器的顯示與隱藏?
- 鼠標(biāo)經(jīng)過時(shí)可以切換CSS嗎?如何實(shí)現(xiàn)?
- overflow與text-indent:-9999px 字體隱藏及input value偏移
- DIVCSS中id于class的區(qū)別詳解
- CSS hack 用CSS條件注釋實(shí)現(xiàn)
- 如何定義標(biāo)題最恰當(dāng)符合Web標(biāo)準(zhǔn)?
- WEB2.0標(biāo)準(zhǔn)教程:第十天自適應(yīng)高度
猜你也喜歡看這些
- CSS實(shí)例:常用的CSS隱藏文字的方法
- DivCSS實(shí)例:符合web標(biāo)準(zhǔn)的嵌入Flash的方法-JS調(diào)用
- 實(shí)現(xiàn)三列布局相同高度的解決辦法
- 用CSS打造評(píng)分星級(jí)效果的一個(gè)實(shí)例
- CSS布局教程:用DIV CSS實(shí)現(xiàn)國(guó)內(nèi)經(jīng)典式三行兩列布局
- DIVCSS菜單:縱向CSS菜單實(shí)例之橙色記憶
- CSS滑動(dòng)式條狀圖表如何實(shí)現(xiàn)?
- DivCSS布局實(shí)例:很實(shí)用的圖文混排CSS列表-富有語義
- CSS實(shí)例教程:用列表ul制作CSS橫向菜單的基礎(chǔ)知識(shí)
- 10個(gè)很酷的涂鴉風(fēng)格國(guó)外網(wǎng)店設(shè)計(jì)展示
- 相關(guān)鏈接:
- 教程說明:
Div+CSS教程-IE對(duì)CSS的渲染引擎hasLayout
。