多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內(nèi)最全I(xiàn)T社區(qū)平臺 聯(lián)系我們 | 收藏本站
阿里云優(yōu)惠2
您當(dāng)前位置:首頁 > web前端 > htmlcss > IE 下對 css 的渲染引擎haslayout

IE 下對 css 的渲染引擎haslayout

來源:程序員人生   發(fā)布時(shí)間:2014-03-16 05:08:20 閱讀次數(shù):2694次
  要想更好的理解 css, 尤其是 IE 下對 css 的渲染,haslayout 是一個(gè)非常有必要徹底弄清除的概念。大多IE下的顯示錯(cuò)誤,就是源于 haslayout。

  什么是 haslayout ?

  haslayout 是Windows Internet Explorer渲染引擎的一個(gè)內(nèi)部組成部分。在Internet Explorer中,一個(gè)元素要么自己對自身的內(nèi)容進(jìn)行計(jì)算大小和組織,要么依賴于父元素來計(jì)算尺寸和組織內(nèi)容。為了調(diào)節(jié)這兩個(gè)不同的概念,渲染引擎采用 了 hasLayout 的屬性,屬性值可以為true或false。當(dāng)一個(gè)元素的 hasLayout 屬性值為true時(shí),我們說這個(gè)元素有一個(gè)布局(layout)

  當(dāng)一個(gè)元素有一個(gè)布局時(shí),它負(fù)責(zé)對自己和可能的子孫元素進(jìn)行尺寸計(jì)算和定位。簡單來說,這意味著這個(gè)元素需要花更多的代價(jià)來維護(hù)自身屠錈嫻哪諶藎?而不是依賴于祖先元素來完成這些工作。因此,一些元素默認(rèn)會有一個(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

  對于并非所有的元素都默認(rèn)有布局,微軟給出的主要原因是“性能和簡潔”。如果所有的元素都默認(rèn)有布局,會對性能和內(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 盒模型中的屬性,目前還未被瀏覽器廣泛支持。

  對于內(nèi)聯(lián)元素(默認(rèn)即為內(nèi)聯(lián)的元素,如 span,或 display:inline; 的元素),

  width 和 height 只在 IE5.x 下和 IE6 或更新版本的 quirks 模式下觸發(fā) hasLayout 。而對于 IE6,如果瀏覽器運(yùn)行于標(biāo)準(zhǔn)兼容模式下,內(nèi)聯(lián)元素會忽略 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)元素可以包含塊級元素而少出問題,因?yàn)樵趧e的瀏覽器中 display: inline 就是內(nèi)聯(lián),不像 IE/Win 一旦內(nèi)聯(lián)元素?fù)碛?layout 還會變成 inline-block。

  haslayout 問題的調(diào)試與解決

  當(dāng)網(wǎng)頁在 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 屬性來對這個(gè)問題進(jìn)行修正了。建議首先要考慮的是設(shè)定元素的 width/height 屬性,其次再考慮其他屬性。

  對 IE6 及更早版本來說,常用的方法被稱為霍莉破解(Holly hack),即設(shè)定這個(gè)元素的高度為 1% (height:1%;)。需要注意的是,當(dāng)這個(gè)元素的 overflow 屬性被設(shè)置為 visible 時(shí),這個(gè)方法就失效了。或者使用 IE 的條件注釋。

  對 IE7 來說,最好的方法時(shí)設(shè)置元素的最小高度為 0 (min-height:0;)。

  haslayout 問題引起的常見 bug

  IE6 及更低版本的雙空白邊浮動 bug

  bug 修復(fù): display:inline;

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

  bug 修復(fù): _height:1%;

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

  bug 修復(fù): _height:1%;
生活不易,碼農(nóng)辛苦
如果您覺得本網(wǎng)站對您的學(xué)習(xí)有所幫助,可以手機(jī)掃描二維碼進(jìn)行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關(guān)閉
程序員人生
主站蜘蛛池模板: 卡通动漫第一页 | 国产日产欧产麻豆精品精品推荐 | 亚洲h视频在线 | 欧美精品一区午夜小说 | 丁香九月婷婷 | 一机毛片 | 欧美猛交xxxx免费看 | 欧区一欧区二欧区三免费 | 欧美亚洲国产精品久久久久 | 亚洲国产精品高清在线一区 | 久久久久无码国产精品一区 | 国产精品18久久久久网站 | 亚洲精品国产一区二区在线 | 国产欧美日韩综合二区三区 | 国产亚洲欧美久久精品 | 成人中文字幕一区二区三区 | 女网址www女影院 | 最近中文字幕免费4 | 国产69精品久久 | 最近免费中文字幕mv视频 | 在线视频精品播放 | 亚洲精品乱码久久久久久蜜桃 | 亚洲大片免费 | 77777_亚洲午夜久久多人 | 欧美巨大另类极品video | 99精品视频在线成人精彩视频 | 欧美色综合天天综合高清网 | 欧美成人a| 国产一级做性视频 | 性高湖久久久久久久久aaaaa | 国产亚洲一区二区三区在线观看 | 欧美一二三区视频 | 欧美超清性videosfree | 日产精品久久久一区二区 | 亚洲高清毛片 | 亚洲天堂网视频 | 亚洲一区二区免费看 | 国产一区二区三区日韩 | 91嫩草私人成人亚洲影院 | 久久99精品久久久久久三级 | 欧美成人精品第一区 |