詳解IE瀏覽器的haslayout屬性及相關(guān)兼容性問題解決

IE,這個令所有網(wǎng)站設(shè)計人員討厭,但又不得不為它工作的瀏覽器。不論是6、7還是8,它們都有一個共同的渲染標(biāo)準(zhǔn)haslayout,所以haslayout 是一個非常有必要徹底弄清除的概念。大多 數(shù)IE下的顯示錯誤,就是源于它。
什么是Layout呢?
"Layout" 是 IE 的一個私有屬性,并不是W3C標(biāo)準(zhǔn)。它決定了一個對象(就是一個標(biāo)簽div、li等)在內(nèi)容中如何顯示、與周圍對象的位置關(guān)系、以及怎樣響應(yīng)程序或用戶產(chǎn)生的事件。
這個屬性可以被一些css強(qiáng)制激活。一些HTML標(biāo)簽?zāi)J(rèn)具有haslayout。
PS:一個對象的layout屬性被激活,它的具體表現(xiàn)就是haslayout=true。我們可以用IE Developer Toolbar工具看到被激活的對象帶有"haslayout = -1"的屬性。
下面這些標(biāo)簽?zāi)J(rèn)擁有haslayout屬性:
- <html>, <body>
- <table>, <tr>, <th>, <td>
- <img>
- <hr>
- <input>, <button>, <select>, <textarea>, <fieldset>, <legend>
- <iframe>, <embed>, <object>, <applet>
- <marquee>
你可能就問:微軟干嘛要設(shè)layout這個東西呢?當(dāng)一個對象的layout被激活時,它以及它的子對象的定位和尺寸計算將獨立進(jìn)行,不受附近對象 的干擾。也就是說它擁有一個獨立的布局(layout)。因此瀏覽器要花費更多的代價來處理擁有haslayout的對象。為了提高性能,微軟增加了 layout這個IE私有的概念。
怎樣激活layout?
下面列出的css屬性可以激活對象的layout:
- position: absolute
設(shè)置絕對定位可能會引發(fā)新的問題。
- float: left|rightright
IE下的浮動也會產(chǎn)生一些莫名其妙的問題。
- display: inline-block
當(dāng)一個內(nèi)聯(lián)元素需要haslayout屬性時就需要用它,但是IE本身不支持inline-block的,只是表現(xiàn)得像標(biāo)準(zhǔn)里說的inline-block。
1.width: 除'auto'外的任意值
優(yōu)先考慮使用該屬性。
2.height: 除'auto'外的任意值
對 IE6 及更早版本來說很常用,該方法被稱為霍莉破解(Holly hack),即設(shè)定這個元素的高度為 1% (height:1%;)。但是要注意,當(dāng)這個元素的 overflow 屬性被設(shè)置為 visible 時,這個方法就失效了。
3.zoom: 除'normal'外的任意值
又一個ie私有屬性,不兼容標(biāo)準(zhǔn)。zoom:1可以在測試或者不追求標(biāo)準(zhǔn)的情況下使用,效果不錯。
- writing-mode: tb-rl
ie私有屬性,不推薦用。
IE7 還有一些額外的屬性:
1.min-height: (任意值)
2.max-height: (除 none 外任意值)
3.min-width: (任意值)
4.max-width: (除 none 外任意值)
5.overflow: (除 visible 外任意值)
6.overflow-x: (除 visible 外任意值)
7.overflow-y: (除 visible 外任意值)
8.position: fixed
重置haslayout
在沒有其它屬性激活layout的情況下,使用下面的css可以重置haslayout屬性:
1.width, height (設(shè)為 "auto")
2.max-width, max-height (設(shè)為 "none")(在 IE 7 中)
3.position (設(shè)為 "static")
4.float (設(shè)為 "none")
5.overflow (設(shè)為 "visible") (在 IE 7 中)
6.zoom (設(shè)為 "normal")
7.writing-mode (從 "tb-rl" 設(shè)為 "lr-t")
display 屬性的不同:當(dāng)用"inline-block"激活了haslayout 屬性時,就算在一條獨立的規(guī)則中覆蓋這個屬性為"block"或"inline",haslayout 這個標(biāo)志位也不會被重置為 false。
把 mid-width, mid-height 設(shè)為它們的默認(rèn)值"0"仍然會賦予 hasLayout,但是 IE 7 卻可以接受一個不合法的屬性"auto"來重置 hasLayout。
觸發(fā) hasLayout 清除浮動
樣例:
- haslayout-clear-float:{width:1px}
或
- .haslayout-clear-float:{height:1px}
或
- .haslayout-clear-float:{zoom:1}
'Layout' 是 IE 的專有概念,它決定了元素如何對其內(nèi)容進(jìn)行定位和尺寸計算,與其他元素的關(guān)系和相互作用,以及對應(yīng)用還有使用者的影響。
'Layout' 可以被某些 CSS property(特性)不可逆的觸發(fā),而某些 HTML 元素本身就具有 layout 。
'Layout' 在 IE 中可以通過 hasLayout 屬性來判斷一個元素是否擁有 layout ,如 object.currentStyle.hasLayout 。
'Layout' 是 IE 瀏覽器渲染引擎的一個內(nèi)部組成部分。在 IE 瀏覽器中,一個元素要么自己對自身的內(nèi)容進(jìn)行組織和計算大小, 要么依賴于包含塊來計算尺寸和組織內(nèi)容。為了協(xié)調(diào)這兩種方式的矛盾,渲染引擎采用了 'hasLayout' 屬性,屬性值可以為 true 或 false。 當(dāng)一個元素的 'hasLayout' 屬性值為 true 時,我們說這個元素有一個布局(layout),或擁有布局。
相關(guān)文章
瀏覽器hack總結(jié) 詳細(xì)的瀏覽器兼容性的快速解決方法
下面小編就為大家?guī)硪黄獮g覽器hack總結(jié) 詳細(xì)的瀏覽器兼容性的快速解決方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起公司小編過來看看吧2016-06-16HTML5的video標(biāo)簽的瀏覽器兼容性增強(qiáng)方案分享
使用HTML5時就應(yīng)該考慮包括桌面以及移動端的瀏覽器兼容問題,特別是視頻方面瀏覽器對解碼的支持會有所不同,所以下面就來分享一個HTML5的video標(biāo)簽的瀏覽器兼容性增強(qiáng)方案分2016-05-19- 這篇文章主要介紹了各種瀏覽器下的CSS Hack兼容性寫法,CSS Hack大致可以分為內(nèi)部Hack和選擇器Hack以及HTML頭部引用Hack,需要的朋友可以參考下2016-03-14
- 用來設(shè)定元素透明度的 Opacity 是CSS 3里的一個屬性。當(dāng)然現(xiàn)在還只有少部分瀏覽器支持,不過各個瀏覽器都有自己的私有屬性來支持,其中包括老版本的Mozilla和Safari2015-11-09
- 火狐瀏覽器怎么切換到IE兼容模式?有很多網(wǎng)頁其他瀏覽器打不開,但是用ie瀏覽器就可以打開,怎么設(shè)置成ie兼容模式呢?下面我們來看看火狐瀏覽器切換到IE兼容模式的詳細(xì)圖文2015-10-27
- 下面小編就為大家?guī)硪黄獪\談瀏覽器的兼容性(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-25