国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

IE7beta2的CSS兼容性_瀏覽器兼容教程

2024-07-11 08:40:57
字體:
來源:轉載
供稿:網友
當IE7 beta1推出的時候,我在第一時間對它作了個測試。當時發現它對CSS的支持幾乎沒有任何變化,著實失望了一陣。MS在最近推出了IE7 beta2,這次有了不少新的改進和變化。但這些改進和變化會導致一些原來正常網頁出現布局錯誤或者原來可以使用的Hack技巧不再可用。MSDN在年初的時候把這些可能產生的問題羅列給開發者(這是原文),這里我把其中比較主要的問題簡單地描述一下,希望能對大家有所幫助。

  注重,在IE7正版發布之前,以下提到所有內容都是有可能變化的。

盒模型變了!!!
  這恐怕是會讓那些使用Web標準建設大型網站的開發者感到背脊發涼的變化,不過不用太擔心,主要的變化是在盒模型對溢出(overflow)內容的處理方法。

  假設有一個100px寬100px高的盒子,在這個盒子里放一個200px寬200px高的圖片。目前IE的正理方法是自動把盒子“撐大”到200px見方。而IE7 beta2的處理方法和FF是一致的:盒子不變,溢出的部分在盒子外面被渲染。也就是說盒子的overflow值真正地使用了W3C的默認值“visible”。

  假如你現有的布局是依靠于IE的“自動撐開”,那么要小心,很可能會出現問題(非凡是動態內容的網頁)。

XML序言(prolog)可能會影響盒模型
  Oh,My GOD!又是盒模型!

  大家知道IE有兩種渲染模式:Quirks Mode和Strict Mode。Quirks Mode基本上是非標準的,包括盒模型在內,它的渲染方式與W3C的標準有些出入。而Strick Mode基本上是標準的(反正都不是絕對標準也不是絕對不標準……)。IE6及以前版本會根據寫在XHTML文檔第一行(也只能是第一行)的DocType聲明來選擇渲染模式。假如發現了一個它能識別的DocType,比如XHTML Transitional或者XHTML Strict等等,它就使用Strict Mode來渲染。其他所有情況下都使用Quirks Mode。

  有些開發者為了顯式地聲明他們的XHTML文檔是一個XML,會在文檔的第一行(問題就在這里,它也必須在第一行)加上XML的序言(prolog)。比如:

<?xml version="1.0" encoding="gb2312"?>  雖然初衷是為了讓文檔更“標準”,但由于IE不認這行字,結果還是按Quirks Mode來渲染。

  IE7 beta2解決這個問題,它會跳過prolog來看檢查DocType。所以可能會出現IE6及以下版本用Quirks Mode渲染而IE7 beta2用Strict Mode渲染的情況。

  其實這個問題輕易解決,在現有的環境下,把prolog直接刪掉就行了,實在是沒什么大的用處。當然想裝作在使用XHTML,事實上還是想用Quirks Mode的人可能得好好想個新辦法了^_^

由于改進bug而失效的Hack技巧

* html
這是一個利用IE Bug的Hack,如下的寫法只有IE會解析其中的內容:

* html{...}* html body{...}現在IE beta2將和大部隊一起把它們忽略掉。

下劃線Hack
這也是一個利用IE Bug的Hack,如下的寫法只有IE會解析其中的內容:

.myclass{
min-height:300px;
_height:300px;
}現在IE beta2將不再解析下劃線開頭的屬性,但是會把它當作一個“用戶自定義”屬性。自定義屬性并不能應用到表現上,但是它會存在于文檔模型中,可以使用腳本來訪問。(這個特性我還沒有測試過)

/**/注釋Hack
這是我最喜歡的Hack技巧之一了。如下的寫法在Strict Mode下面會對IE6透明(IE5.x是會解析的),但是現在IE7 beta2將會解析它:

.myclass{
height/**/:300px;
}由于增強功能而失效的Hack技巧
原來IE不支持以下寫法,現在可以了:

child選擇符Hack
html > body{
height:300px;
}相鄰選擇符Hack
head body{
height:300px;
}相鄰選擇符和first-child偽類選擇符
head:first-child body{
height:300px;
}這些都算不上什么壞消息,反正我從來不用這些Hack^_^

俺的頁面亂咧,咋辦?
  在MSDN的那篇文章上給出了一些解決方案,從我的角度來看都是些治標不治本、隔靴搔癢的方案。要不用JS來做CSS的工作,要不只針對IE來載入特定的CSS。所以建議大家:等!一等IE7的正式版,在正式版出來之前,什么都有可能變。二等偉大的CSS社區的牛牛們找出更多的Hack技巧。IE7不可能做得和FF一模一樣,也不可能和IE6一模一樣,反正總會有點不一樣的,就利用那點不一樣的東西來做Hack。

  雖然用各種Hack是件很無奈的事情,但現實就是這樣,我們在努力影響這個行業的同時只有好好適應它,所以私底下很希望能看到用中國人名字命名的Hack出現。

  Fight!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 新竹市| 剑阁县| 泌阳县| 丹巴县| 社旗县| 望都县| 尚志市| 雅安市| 车险| 夏邑县| 长乐市| 井陉县| 灯塔市| 中阳县| 张家川| 开平市| 石城县| 科技| 师宗县| 萍乡市| 延庆县| 调兵山市| 咸阳市| 闸北区| 黄石市| 新营市| 虎林市| 石家庄市| 莆田市| 黑山县| 无极县| 双辽市| 晴隆县| 新宁县| 江陵县| 武定县| 罗江县| 西安市| 汕尾市| 治县。| 怀安县|