网页制作cnn6文章简介:IE8有4种模式:IE5.5怪异模式、IE7标准模式、IE8几乎标准模式、IE8标准模式。 |
Trigger-Standardmodus
1. DOCTYPE-Anweisung hinzufügen, wie zum Beispiel:
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> < !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> < !DOCTYPE html>
2.
Seltsamer Modus auslösen
1. Keine Doctype-Deklaration, alte HTML-Version definieren (unter HTML4, z. B. 3.2)
2. XML-Deklaration hinzufügen, kann unter ie6 ausgelöst werden
3. Fügen Sie HTML zwischen der XML-Deklaration und dem DOCTYPE von XHTML hinzu Hinweis: Kann unter ie7
< ausgelöst werden. ..>
5. Platz vor
1. Setzen Sie X-UA-kompatibles Meta
IE=7 (7<= Wert <8): IE7-Standard erzwingen (unabhängig davon). Seite Ob es DOCTYPE gibt)
IE=EmulateIE7: DOCTYPE folgen (mit DOCTYPE-IE7-Standard; kein seltsamer DOCTYPE-IE5-Modus)
IE=EmulateIE8: DOCTYPE folgen (DOCTYPE-IE8-Fast-Standardmodus (oder IE8-Standardmodus). ); Kein seltsamer DOCTYPE-IE5-Modus)
IE=8, IE=Edge, IE=99, IE=9,9 (größer oder gleich 8): Mit DocType-Verwenden Sie den Fast-Standard-Modus oder IE8-Standard ohne DocType -IE8-Standard.
Keine ".
Hinweis 1: Wenn X-UA-Compatible unter dem Tag geschrieben wird, ist die Einstellung von X-UA-Compatible ungültig.
Hinweis 2: Wenn die Seite und der Server-HTTP-Header auf X-UA-kompatibel eingestellt sind, verwenden Sie die X-UA-kompatible Einstellung der Seite. Wenn die Seite nicht über X-UA-kompatibel verfügt, wird der im HTTP-Header festgelegte Wert verwendet.
Hinweis 3: Die Bedeutung und der Auslöser des Modus „Fast Standards“ werden unten im Abschnitt „Modus „Fast Standards““ erläutert.
Hinweis 4: Für den Wert von IE=xx wird versucht, xx in den nächstgelegenen Wert umzuwandeln. Beispiel: IE=7,789 -> IE=7; zwischen 5 und 6 ->IE=5; größer oder gleich 8;
Hinweis 5: IE=4, IE=3, IE=0,1, IE=-7, die kleiner als 5 sind, umfassen IE=IE8, IE=IE7, IE=IE6, IE=a, IE=b, IE =bcd, das gleiche wie ohne X-UA-Kompatibilität. Es kann verstanden werden, dass X-UA-Compatible auf einen ungültigen Wert eingestellt ist, also überspringen Sie hier.
IE=7(7<= value<8): IE7-Standard erzwingen (unabhängig davon, ob die Seite DOCTYPE hat)
IE=EmulateIE7: DOCTYPE folgen (mit DOCTYPE-IE7-Standard; ohne seltsamen DOCTYPE-IE5-Modus). )
IE =EmulateIE8: Folgen Sie DOCTYPE (DOCTYPE-IE8 fast Standard oder IE8-Standard; kein seltsamer DOCTYPE-IE5-Modus)
IE=8, IE=Edge, IE=99, IE=9.9 (größer als oder gleich 8): es gibt doctype – Verwenden Sie den Fast-Standards-Modus (oder IE8-Standards);
Hinweis: Nach der Einstellung von X-UA-Compatible (Meta- oder HTTP-Header) werden die Einstellungen der Kompatibilitätsansicht des Clients überschrieben. Erzwingt die Verwendung des durch „Kompatibilitätsansicht“ festgelegten Modus (gibt Priorität), es gibt eine Einstellung für „Kompatibilitätsansicht“ (doctype-IE7-Standard, kein seltsamer doctype-IE5-Modus), es gibt eine „Kompatibilitätsansicht“; Folgen Sie doctype, kein seltsamer Doctype-IE5-Modus.
IE9 hat 7 Modi: IE5.5 Weird Mode, IE7 Standard Mode, IE8 Almost Standard Mode, IE8 Standard Mode, IE9 Almost Standard Mode, IE9 Standard Mode, XML Mode
IE9 und IE8 ist im Grunde dasselbe:
Anders, der Test ergab, dass die beiden CSS-Hack-Symbole „-“ und „_“ von IE8 erkannt werden, „-“ jedoch von IE9 nicht.IE=7(7<= Wert<8) – IE7-Standard erzwingen (unabhängig davon, ob die Seite DOCTYPE hat oder nicht)
IE=8(8<= Wert<9) – IE8-Standard erzwingen, mit Doctype - IE8-Fast-Standardmodus (oder IE8-Standard) verwenden, kein Doctype-IE8-Standard
IE=EmulateIE7, EmulateIE8 Die gleiche Situation wie IE8 oben
IE=9, IE=Edge (Wert>=9) – mit Doctype - Verwenden Sie den Fast-Standard-Modus (oder IE9-Standards). Verlassen Sie sich wie bei IE8 auf den Doctype, um den IE9-Standardmodus oder den IE9-Standardmodus auszuwählen.
IE=(value<0), IE=IE8, IE=IE7, IE=IE6, IE=a, IE=b, IE=bcd, IE=xxx sind so unzuverlässig, oder setzen Sie X-UA-kompatibel Meta wird nach dem Tag geschrieben. Diese Situationen sind die gleichen wie ohne X-UA-Compatible: Bestimmen Sie zunächst die „Kompatibilitätsansicht“ und es gibt eine Einstellung für „Kompatibilitätsansicht“. Standard, kein DocType-Weird-Modus); „Kompatibilitätsansicht“ ist nicht eingestellt, es gibt DOCTYPE-Follow DocType, kein DocType-Weird-Modus.
Besondere Schreibweise X-UA-kompatibel
msdn上面提到了X-UA-Compatible值设置成"IE=9; IE=8; IE=5"这样的,意思就是优先最前面的IE9,没IE9就用IE8,没IE8就IE5,并且并不推荐在生产环境下使用。
触发Google Chrome Frame:
可以和IE的X-UA-Compatible混搭:比如:。这样写的好处:可以让ie在最好的渲染方式下渲染页面。
"IE=edge,chrome=1",可以写成"chrome=1,IE=edge"、"chrome=1; IE=edge"。
几乎标准模式(Almost Standards Mode)
Firefox 1+、Safari、Chrome、Opera(从7.5开始)和IE8/IE9增加了一个"几乎标准模式",它实现传统的表格单元格的垂直尺寸(没有严格的遵照CSS2规范)。
意思就是,比如下面的代码:
<table style="border:1px solid blue;" cellspacing="0"> < tr><td><img style="border:1px solid red" width="364" height="126" src="http://www.google.com/images/logos/ps_logo2.png"/></td></tr> < /table>
比如在IE7标准模式下,图片底部和table是没空白的;"几乎标准模式"下,图片底部和table也是没空白的;而较新的浏览器在标准模式下图片底部和table会有个空白。
@see:https://developer.mozilla.org/en/Images,_Tables,_and_Mysterious_Gaps
下面的DOCTYPE都可触发IE8标准模式:
< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> < !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> < !DOCTYPE html>
触发IE8几乎标准模式:
< !DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN" "http://www.w3.org/TR/html4/frameset.dtd">
Mac IE5、IE6/7、Opera(<7.5)和Konqueror无几乎标准模式(它们没有严格遵循CSS2规范,实际上,它们的标准模式更接近几乎标准模式)。HTML5把这种模式叫“受限怪异模式(limited quirks mode)”。
XML模式 - application/xhtml+xml Content
Firefox、Safari、Chrome和Opera中,HTTP头设置了MIME-type(Content-Type为application/xhtml+xml时),会触发XML模式。在XML模式中,浏览器会严格地以XML解析XHTML文档(很严格,用过W3C的xhtml验证的同学应该明白,比如"&"要用"&"+"amp;"、
要用
)。
任何一个XHTML文档的解析错误会导致停止解析,FF/SF/CH/OP会直接报XML解析错误,IE9可以在开发人员工具的console里面看到报错。
MacIE5、IE6/7/8不支持application/xhtml+xml。
发现IE9下使用此模式,doctype是无所谓的, 这句命名空间必须的,没设置命名空间css会以文本解析而失效。
同时XML模式下,X-UA-Compatible的设置将会无效。
总结:
X-UA-Compatible只有IE>=8才识别,所以他们可以用doctype声明、X-UA-Compatible、兼容性视图设置来改变模式。
IE6/7却依靠DOCTYPE来改变标准或怪异模式,类似这些低版本的浏览器下的标准模式,接近与“先进”浏览器下的几乎标准模式,因为它们都没有严格遵循CSS2规范。并且他们同样在标准模式下,各自的渲染还是是有差别的。没差别就不会有css hack的诞生。
IE6-IE9下,怪异模式都在IE5.5下。
不需要写X-UA-Compatible,用css也完全可以搞定各个版本IE的解析不同。
模式、版本不同,不仅仅css解析不同,js的解析也有不同。
了解浏览器解析模式的不同,可以避免我们辛苦写出的标准代码被怪异所残害。
让开发者更注重遵循标准,无论在生产效率还是在协作、沟通上都有好处滴。
现在几乎人人都用标准的doctype来声明文档,所以纠结标准、怪异模式对工作的影响不太大。
Das obige ist der detaillierte Inhalt vonBrowser-Parsing-Modus: Detaillierte Erläuterung der Verwendung von DOCTYPE-Deklarationsproblemen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!