zoukankan      html  css  js  c++  java
  • Activating Browser Modes with Doctype

    Activating Browser Modes with Doctype

    In order to deal both with content written according to Web standards and with content written according to legacy practices that were prevalent in the late 1990s, today’s Web browsers implement various engine modes. This document explains what those mode are and how they are triggered.

    The Scope of this Document

    This document covers mode switching as it applies to Firefox and other Gecko-based browsers, Safari, Chrome and other WebKit-based browsers, Opera, Konqueror, Internet Explorer for Mac and Internet Explorer for Windows and browsers that embed IE. Instead of referring to the names of browser engines, the names of the best-known browsers using each engine are used instead.

    This document focuses on the mode selection mechanism and does not document the exact behaviors of each mode. The purpose of this document is to give you information on how to avoid the legacy modes. The purpose of this document is not to facilitate cherry-picking behaviors by deliberately choosing legacy modes.

    The Modes

    Here are the various modes:

    Modes for text/html Content

    The choice of the mode for text/html content depends on doctype sniffing (discussed later in this document). In IE8 and IE9, the mode also depends on other factors. However, by default even in IE8 and IE9, the mode depends on the doctype for non-intranet sites that are not on a blacklist supplied by Microsoft.

    It cannot be stressed enough that the exact behavior of the modes varies from browser to browser even though discussion in this document has been unified.

    Quirks Mode

    In the Quirks mode the browsers violate contemporary Web format specifications in order to avoid “breaking” pages authored according to practices that were prevalent in the late 1990s. Different browsers implement different quirks. In Internet Explorer 6, 7, 8 and 9, the Quirks mode is effectively frozen IE 5.5. In other browsers, the Quirks mode is a handful of deviations from the Almost Standards mode.

    If you are authoring new pages now, you are supposed to comply with the relevant specifications (CSS 2.1 in particular) and use the Standards mode.

    Standards Mode

    In the Standards mode the browsers try to give conforming documents the specification-wise correct treatment to the extent implemented in a particular browser.

    Since different browsers are at different stages of compliance, the Standards mode isn’t a single target, either.

    HTML 5 calls this mode the “no quirks mode”.

    Almost Standards Mode

    Firefox, Safari, Chrome, Opera (since 7.5), IE8 and IE9 also have a mode known as “the Almost Standards mode”, which implements the vertical sizing of table cells traditionally and not rigorously according to the CSS2 specification. Mac IE 5, Windows IE 6 and 7, Opera prior to 7.5 and Konqueror do not need an Almost Standards mode, because they don’t implement the vertical sizing of table cells rigorously according to the CSS2 specification in their respective Standards modes anyway. In fact, their Standards modes are closer to the Almost Standards mode than to the Standards mode of newer browsers.

    HTML 5 calls this mode the “limited quirks mode”.

    IE7 Mode

    IE8 and IE9 have a mode that is mostly a frozen copy of the mode that was the Standards mode in IE7. Other browsers do not have a mode like this, and this mode is not specified by HTML5.

    IE8 Standards Mode

    IE9 has a mode that is mostly a frozen copy of the mode that was the Standards mode in IE8. Other browsers do not have a mode like this, and this mode is not specified by HTML5.

    IE8 Almost Standards Mode

    IE9 has a mode that is mostly a frozen copy of the mode that was the Almost Standards mode in IE8. Other browsers do not have a mode like this, and this mode is not specified by HTML5.

    The Mode for application/xhtml+xml Content (XML Mode)

    In Firefox, Safari, Chrome, Opera and IE9, the application/xhtml+xml HTTP Content-Type (not a metaelement nor a doctype!) triggers the XML mode. In the XML mode, these browsers give the specification-wise correct treatment for XML documents to the extent implemented in a particular browser.

    IE 6, 7 and 8 do not support application/xhtml+xml. Neither does Mac IE 5.

    In the WebKit-based Nokia S60 Browser, the application/xhtml+xml HTTP Content-Type does not trigger the XML mode due to concerns of compatibility with ill-formed content in mobile walled gardens. (Legacy “mobile browsers” don’t use a real XML parser and, therefore, ill-formed content has been labeled as XML.)

    I have not tested the default browser on Symbian3.

    I have not tested Konqueror sufficiently to say what exactly happens in that browser.

    Non-Web Modes

    Some engines have modes that are not relevant to Web content. These modes are only mentioned here for completeness. Opera has a WML 2.0 mode. WebKit on Leopard has a special mode for legacy Dashboard widgets. WebKit also has hacks for applications that embed WebKit on Mac OS X.

    The Effects

    Here are the main effects of the modes:

    Layout

    The modes for text/html mainly affect CSS layout. For example, not inheriting styles into tables is a quirk. In some browsers, the box model changes to the IE 5.5 box model in the Quirks mode. This document does not emumerate all the layout quirks.

    In the Almost Standards mode (in browsers that have one), the height of table cells containing only images is computed differently compared to the Standards mode.

    In the XML mode, selectors have different case-sensitivity behavior. Furthermore, special rules for the HTML body element do not apply in older versions of browsers that do not implement the latest CSS 2.1 changes.

    Parsing

    There are also some quirks that affect HTML and CSS parsing and would cause conforming pages to be misparsed. These quirks are toggled on and off with quirky layout. However, it is important to realize that the Quirks mode vs. Standards mode is predominantly about CSS layout and parsing—not HTML parsing. In browsers that have an HTML5-compliant HTML parser, there is exactly one parsing quirk.

    Some people misleadingly refer to the Standards mode as “strict parsing mode”, which is misunderstood to imply that browsers enforced HTML syntax rules and that a browser could be used to assess the correctness of markup. This is not the case. The browsers do tag soup fix-ups even when the Standards mode layout is in effect. (In 2000 before Netscape 6 was released, Mozilla actually had parser modes that enforced HTML syntax rules. These modes were incompatible with existing Web content and were abandoned.)

    Another common misconception is related to XHTML parsing. It is often thought using an XHTML doctype gains different parsing. It does not. XHTML documents served as text/html are parsed using the same parser that is used for HTML. As far as browsers are concerned, XHTML served as text/html is just “tag soup with croutons” (an extra slash here and there).

    Only documents served using an XML content type (e.g. application/xhtml+xml or application/xml) trigger the XML mode for parsing in which case the parser is totally different from the HTML parser.

    Scripting

    Although the Quirks mode is primarily about CSS, there are some scripting quirks as well. For example, in Firefox’s Quirk mode, the HTML id attribute establishes object references from the global scripting scope as in IE. The effects on scripting are more dramatic in IE8 and IE9 than in other browsers.

    In the XML mode, some DOM APIs behave drastically differently, because the DOM API behavior for XML is defined to be incompatible with the HTML behavior.

    Doctype Sniffing (aka. Doctype Switching)

    Browsers today use doctype sniffing in order to decide the engine mode for text/html documents. This means that the mode is picked based on the document type declaration (or the lack thereof) at the beginning of an HTML document. (This does not apply to documents served with an XML content type.)

    A document type declaration (doctype) is a syntactic artifact of SGML—a legacy markup framework that HTML prior to HTML5 was purportedly defined in terms of. In the HTML 4.01 specification, the document type declaration is said to communicate HTML version information. Despite the name “document type declaration” and despite what the HTML 4.01 specification says about “version information”, the document type declaration is not an appropriate means for classifying SGML or XML documents as documents of a particular type even though it seems it was supposed to be (hence the name). (More on this in the addendum.)

    Neither the HTML 4.01 specification nor ISO 8879 (SGML) says anything about using the document type declaration as an engine mode switch. Doctype sniffing is based on the observation that at the time doctype sniffing was devised the vast majority of quirky documents either didn’t have a document type declaration or they referenced an old DTD. HTML5 acknowledges this reality and defines the doctype in text/html as a mode switch only.

    typical pre-HTML5 document type declaration contains (separated by white space) the string “<!DOCTYPE”, the generic identifier of the root element (“html”), the string “PUBLIC”, a public identifier of a DTD in quotes, possibly a system identifier (an URL) of the same DTD and the character “>”. HTML5 simplies the doctype to “<!DOCTYPE html>”. The document type declaration is placed in the document before the start tag of the root element.

    Choosing a Doctype

    text/html

    In a nutshell: Here are simple guidelines for choosing a doctype for a new text/html document:

    Standards mode, cutting edge validation

    <!DOCTYPE html>

    This is the right thing to do unless you have a specific reason to avoid it. With this doctype, you can validate new features such as <video><canvas> and ARIA. Please be sure to test your page in the latest versions of the top browsers.

    Standards mode, legacy validation target

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">

    This doctype also triggers the standards mode, but lets you stick to legacy validation in case you want to avoid new features or more precise validation of old features.

    You’d like to use the Standards mode, but you use sliced images in table layouts and don’t want to fix them

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

    This gives you the Almost Standards mode. Please note that your layouts based on sliced images in tables are likely to break if you later move to HTML5 (and, hence, the full Standards mode).

    You willfully want the Quirks mode

    No doctype.

    Please don’t do this. Willfully designing for the Quirks mode will come and haunt you, your coworkers or your successors in the future—when no one even cares about Windows IE 6 anymore (already no one cares about Netscape 4.x and IE 5). Designing for the Quirks mode is a bad idea. Trust me.

    If you still want to support Windows IE 6, it is better to apply specific hacks for it usingconditional comments than to regress other browsers into the Quirks mode.

    I am not recommending any of the XHTML doctypes, because serving XHTML as text/html is considered harmful. If you choose to use an XHTML doctype anyway, please note that the XML declaration makes IE 6 (but not IE 7!) trigger the Quirks mode.

    application/xhtml+xml

    The simple guideline for application/xhtml+xml is not to use a doctype at all. This way the page cannot be “strictly conforming” XHTML 1.0, but that does not matter. (Please see the Addendumbelow.)

    IE8 and IE9 Complications

    It was announced on A List Apart that IE8 would use a meta element-based mode switch in addition to doctype being a factor in the mode choice. (See commentary by Ian HicksonDavid BaronDavid Baron againRobert O’Callahan and Maciej Stachowiak.)

    IE8 has four modes: IE 5.5 quirks mode, IE 7 standards mode, IE 8 almost standards mode and IE 8 standards mode. IE9 has seven modes: IE 5.5 quirks mode, IE 7 standards mode, IE 8 almost standards mode, IE 8 standards mode, IE 9 almost standards mode, IE 9 standards mode and XML mode. The choice of mode depends on data from various sources: doctype, a meta element, an HTTP header, periodically downloaded data from Microsoft, the intranet zone, settings made by the user, settings made by an intranet administrator, the mode of the frame parent if any and a UI button togglable by the user. (With other apps that embed the engine, the mode also depends on the embedding application.)

    The lucky thing is that IE8 and IE9 use doctype sniffing roughly like other browsers if:

    • There is no X-UA-Compatible HTTP header set by the author.
    • There is no X-UA-Compatible meta tag set by the author.
    • Microsoft has not placed the domain name of the site on a blacklist.
    • An intranet admin has not placed the site on a blacklist.
    • The user has not pressed the Compatibility View button (or otherwise added the domain to a user-specific blacklist).
    • The site is not in the intranet zone.
    • The user has not chosen to display all sites as in IE7.
    • The page is not framed by a Compatibility Mode page.

    For the points other than the two X-UA-Compatible cases, IE8 and IE9 perform doctype sniffing like IE7. The IE7 emulation is called Compatibility View.

    In the X-UA-Compatible cases, IE8 and IE9 behave radically differently from other browsers. For the behavior of IE8, please see an appendix on this page or a flowchart available in PDF and PNGformats. (Contrast with the chart for other browsers as PDF.) There is also a unified chart of IE 5.5 through 9 (potentially with Chrome Frame) modes as PDF. (I intend to make an IE9-only view of this chart later.)

    Unfortunately, without an X-UA-Compatible HTTP header or meta tag, IE8 and IE9 let the user accidentally drop your page from their most standards mode to the IE7 mode that emulates the standards mode of IE7 even if you used a proper doctype. Worse, an intranet admin may do this. Also, Microsoft may have blacklisted the entire domain you use (e.g. mit.edu!).

    To counter these effects, a doctype isn’t enough and you need an X-UA-Compatible HTTP header ormeta tag.

    In a nutshell: Here are simple guidelines for choosing an X-UA-Compatible HTTP header or meta tag for a newtext/html document that already has a doctype that triggers the standards mode or almost standards mode in other browsers:

    Your domain is not on Microsoft’s blacklist and you care more about not having to have browser-specific cruft than about making sure users can’t regress the rendering to IE7 behavior

    You don’t need to include an X-UA-Compatible HTTP header or meta tag.

    Your domain is on Microsoft’s blacklist, your domain (like iki.fi!) has other authors whose broken sites may induce users to enable Compatibility View for the whole domain, you are concerned about Google or Digg framing your site or you want to make sure users cannot enable the Compatibility View

    Include either the following meta element (which in invalid in HTML5) on your page <meta http-equiv="X-UA-Compatible" content="IE=Edge"> (before any script elements!) or set the following HTTP header on your page: X-UA-Compatible: IE=Edge

    Your site worked in IE7 but breaks in IE8 or IE9

    First, include either the following meta element (which in invalid in HTML5) on your page <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7"> (before any script elements!) or set the following HTTP header on your page: X-UA-Compatible: IE=EmulateIE7

    Then fix your site not to rely on non-standard IE7 behaviors and migrate to IE=Edge.

    Your site worked in IE8 but breaks in IE9

    First, include either the following meta element (which in invalid in HTML5) on your page <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE8"> (before any script elements!) or set the following HTTP header on your page: X-UA-Compatible: IE=EmulateIE8

    Then fix your site not to rely on non-standard IE8 behaviors and migrate to IE=Edge.

    Links to Related Pages


    Addendum: A Plea to Implementors and Spec Writers Working with XML

    Please don’t bring doctype sniffing to XML.

    Doctype sniffing is a tag soup solution to a tag soup problem. Doctype sniffing was devised afterthe HTML 4 and CSS2 specs had been written as a heuristic way to distinguish legacy documents from documents whose authors might expect conforming behavior.

    Sometimes it is suggested that doctype sniffing be used on the XML side as well for dispatching to different handlers, for recognizing the vocabulary in use, or for activating features. This is a bad idea. Dispatching and vocabulary recognition should be based on namespaces and feature activation should be based on explicit processing instructions or elements.

    The whole concept of well-formedness was introduced to allow DTDless parsing of XML and, by extension, doctypeless documents. In formal terms, if two XML documents have the same canonical form and an app treats them differently (and the difference is not due to opting not to process external entities), chances are the app is broken. In practical terms, if two XML documents cause the same content to be reported (qnames ignored) to SAX2 ContentHandler and an app treats the documents differently, chances are the app is broken. Considering that as a Web author you cannot trust that everyone parsing your pages uses an XML processor that resolves external entities (even if some browsers appear to do so because they map certain public ids to an abridged DTD for entity definitions), inserting a doctype in XML intended for the Web is mostly pointless and often done out of a cargo cultish habit. (You can still validate against a DTD using the DTD override feature of the W3C Validator, although the W3C Validator will say that the result is only tentatively valid. Or better yet, you can use RELAX NG validation, which does not pollute the document with schema references.) Requiring a doctype only for sniffing would be silly, even though that is the situation with HTML in practice.

    Moreover, when a lower-level spec defines two things that are equivalent, a higher-level spec should not try to give different meanings to the two things. Consider <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">. If the public identifier is removed, the same DTD is still designated and, therefore, the doctype <!DOCTYPE html SYSTEM "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> means the same as the previous doctype. Should they be sniffed differently? The idea can be carried further. Suppose the DTD is copied to example.com and named foobar.dtd: <!DOCTYPE html SYSTEM "http://example.com/foobar.dtd">. How could that one be sniffed? The meaning is the same. The whole DTD could even be pasted inline!

    To put it another way, if you have #include "foo.h", you should not bind any black magic to the name foo.h, because it should be permissible to paste the contents of foo.h inline or copy the contents of foo.h to bar.h and say #include "bar.h".

    The reason I don’t bother making the same argument with HTML and SGML is that Web browsers don’t use real SGML parsers for parsing HTML, so I don’t think it is useful to pretend that SGML is being dealt with. However, if you are not convinced yet, please see W. Eliot Kimber’s comp.text.sgml post about the matter.

    Appendix: Handling of Some Doctypes in text/html

    In the following table, Quirks Mode, Standards Mode and Almost Standards Mode are denoted by Q, S and A, respectively. When a browser only has two modes, the Standards Mode is marked as “S”, if the line height in table cells works as in Mozilla’s Standards Mode, and as “A”, if the line height in table cells works as in Mozilla’s Almost Standards Mode.

    Please note that XHTML served using an XML content type is rendered in the XML mode.

    The purpose of this table is not to suggest that all the doctypes listed in the table are reasonable choices for new pages. The purpose of this table is to show what data I am basing my recommendations on.

    The following shorthand notation is used in the column headers:

    NS6
    Mozilla 0.6…0.9.4 and Netscape 6.0…6.2.3
    Old Moz
    Mozilla 0.9.5 through 1.1 alpha and Mozilla 1.0
    Moz & Safari & Opera 10 & HTML5
    Mozilla 1.0.1, Mozilla 1.1 beta and later, Firefox, Netscape 7 and later, Safari 0.9 and later, Opera 10 and later, Chrome, Konqueror 3.5, the HTML5 specified behavior
    Opera 9.0
    Opera 9.0…9.20
    IE 8, IE 9 & Opera 9.5
    IE 8 or IE 9 by default when there is no X-UA-Compatible override nor a Compatibility View override (“A” means the IE8 Almost Standards mode for IE8 and IE9 Almost Standards mode for IE9), Opera 7.5…8.54 and 9.5…9.6
    IE 7 & Opera 7.10
    Windows IE 7, IE 8 with Compatibility View enabled but without X-UA-Compatible override (in this case “A” means the IE7 mode) and Opera 7.10…7.23
    IE 6 & Opera 7.0
    Windows IE 6 and Opera 7.0…7.03
    Mac IE 5
    Mac IE 5.0…5.2.3
    Konq 3.2
    Konqueror 3.2.2…3.3 (possibly also 3.1…3.2.1; I have not been able to confirm)
    DoctypeNS6Old MozMoz &
    Safari &
    Opera 10
    & HTML5
    Opera 9.0IE 8, IE 9 & Opera 9.5IE 7 & Opera 7.10IE 6 & Opera 7.0Mac IE 5Konq 3.2
    NoneQQQQQQQQQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">QQQQQQQQQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">SSSSSAAAA
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">SSSSSAAQA
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN" "http://www.w3.org/TR/html4/strict.dtd">SSSSSAAAA
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">SSSSSAAAA
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">QQQQQQQQQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">QQQQQQQQQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">SSAAAAAAQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/1999/REC-html401-19991224/loose.dtd">QSAAAAAAQ
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">QQQQAAAAQ
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">SSSSSAAAA
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN" "http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">SSSSSAAAA
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">SSSSSAAAA
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">SSAAAAAAQ
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
    SSSSSAQAQ
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML Basic 1.0//EN" "http://www.w3.org/TR/xhtml-basic/xhtml-basic10.dtd">
    SSSSSAQAQ
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
    SSSSSAQAQ
    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    SSAAAAQAQ
    <!DOCTYPE HTML PUBLIC "ISO/IEC 15445:2000//DTD HTML//EN">QSSQQQQQQ
    <!DOCTYPE HTML PUBLIC "ISO/IEC 15445:2000//DTD HyperText Markup Language//EN">QSSSSAAAQ
    <!DOCTYPE HTML PUBLIC "ISO/IEC 15445:1999//DTD HTML//EN">SSSQQQQQQ
    <!DOCTYPE HTML PUBLIC "ISO/IEC 15445:1999//DTD HyperText Markup Language//EN">SSSSSAAAQ
    <!DOCTYPE html>QSSSSAAA

    Historical Notes

    Mozilla’s doctype sniffing code has changed substantially in October 2000, in September 2001 and in June 2002. This document describes the situation with Mozilla builds made available at ftp.mozilla.org on 2000-10-19 and later (and with Netscape 6.x). This document does not address the way doctype sniffing worked in Mozilla M18 (and Netscape 6.0 PR3). Safari’s doctype sniffing code has also changed substantially since the first public beta. This document does not cover the behavior of versions earlier than v73 aka. 0.9.

    Konqueror’s doctype sniffing code prior to version 3.5 appears to come from a very early version of Safari. Konqueror now matches Safari whose doctype sniffing code comes from Mozilla.

    As can be seen from the table, Opera’s doctype sniffing has gradually moved from being IE-like to towards being Mozilla-like, although Opera 9.5 and 9.6 regressed on the way. At the same time, the layout behavior of Opera’s Quirks mode has shifted from imitating the Quirks mode of IE 6 towards the Quirks mode of Mozilla.

    Appendix: IE8’s Mode Selection

    Start: Go to “X-UA-Compatible meta?”.

    X-UA-Compatible meta?
    IE=7: Use IE7 Standards.
    IE=EmulateIE7: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    IE=IE8 or IE=IE7 or IE=a or IE=EmulateIE8 or absent or has script first: Go to “X-UA-Compatible HTTP Header?”.
    IE=8 or IE=Edge or IE=99 or IE=9.9: Go to “Almost Standards Doctype?”.
    IE=5: Use Quirks (IE 5.5).
    X-UA-Compatible HTTP Header?
    IE=7: Use IE7 Standards.
    IE=EmulateIE7: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    IE=IE8 or IE=IE7 or IE=a or IE=EmulateIE8 or absent: Go to “Display All Web Sites… Pref Set?”.
    IE=8 or IE=Edge or IE=99 or IE=9.9: Go to “Almost Standards Doctype?”.
    IE=5: Use Quirks (IE 5.5).
    Quirky or No Doctype? (Compatibility Mode)
    Yes: Use Quirks (IE 5.5).
    No: Use IE7 Standards.
    Display All Web Sites… Pref Set?
    Yes: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    No: Go to “Display Intranet Sites… Pref Set?”.
    Display Intranet Sites… Pref Set?
    Yes: Go to “Is the site in the Intranet Zone?”.
    No: Go to “Domain on MS-Maintained List?”.
    Is the Site in Intranet Zone?
    Yes: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    No: Go to “Domain on MS-Maintained List?”.
    Domain on MS-Maintained List?
    Yes: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    No: Go to “Framed by Compatibility Mode page?”.
    Framed by Compatibility Mode page?
    Yes: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    No: Go to “Compatibility Mode Button Pressed?”.
    Compatibility Mode Button Pressed?
    Yes: Go to “Quirky or No Doctype? (Compatibility Mode)”.
    No: Go to “Quirky or No Doctype? (IE8)”.
    Quirky or No Doctype? (IE8)
    Yes: Use Quirks (IE 5.5).
    No: Go to “Almost Standards Doctype?”.
    Almost Standards Doctype?
    Yes: Use IE8 Almost Standards.
    No: Use IE8 Standards.

    The steps are available as a flowchart in PDF and PNG formats.

    Acknowledgments

    Thanks to Simon Pieters, Lachlan Hunt and Anne van Kesteren for their help with correcting the mode table for various Opera versions and for their comments. Thanks to Simon Pieters for the text alternative for the IE8 flowchart.

    Copyright Henri Sivonen

    转自: http://hsivonen.iki.fi/doctype/ 
     

  • 相关阅读:
    SPAN和DIV的区别
    利用XMLHTTP无刷新添加数据之Post篇
    在Asp.net中上传大文件的解决方法
    在事务中执行批量复制操作
    Microsoft Visual SourceSafe 使用指南
    恢复只有MDF文件的MS SQL数据库
    配置sql server 2000以允许远程访问
    转: Bill Gates 哈佛大学毕业典礼演讲1
    用于对数据库进行操作的类库经验的总结
    用于对数据库进行操作的类库经验的总结 (二)
  • 原文地址:https://www.cnblogs.com/lyson/p/2495047.html
Copyright © 2011-2022 走看看