`
#rethink#
  • 浏览: 46899 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

IE浏览器:定义文档兼容性

阅读更多

转载自:http://msdn.microsoft.com/zh-cn/library/cc288325(v=VS.85).aspx#配置_Web_服务器以指定默认兼容性模式

 

更新日期: 2009 年 2 月

文档兼容性可定义 Internet Explorer 呈现网页的方式。 本文将介绍文档兼容性、如何为网页指定文档兼容性模式以及如何确定网页的文档模式。

简介

为了帮助确保您的网页在将来的 Internet Explorer 版本中具有一致的外观,Internet Explorer 8 引入了文档兼容性。 文档兼容性是对 Microsoft Internet Explorer 6 中引入的兼容性模式的扩展,使您可以选择 Internet Explorer 用于显示网页的特定呈现模式。

本文将说明文档兼容性的必要性,列出对近来的 Internet Explorer 版本可用的文档兼容性模式,并演示如何选择特定的兼容性模式。

了解文档兼容性的必要性

Internet Explorer 的每个主要版本中都会添加一些功能,旨在使浏览器更易于使用、提高安全性以及更紧密地支持行业标准。 随着 Internet Explorer 的功能不断增加,将会出现较早的网站可能无法正常显示的风险。

为了最大程度地降低这种风险,Internet Explorer 6 允许 Web 开发人员选择 Internet Explorer 用来解释和显示其网页的方式。 默认为“Quirks 模式”;在这种模式下,将按照使用较旧的浏览器版本查看网页的方式来显示网页。 “标准模式”(也称为“严格模式”)的特点是可提供对行业标准的最大支持;但是,若要利用此增强的支持,网页中需要包括适当的<!DOCTYPE> 指令。

如果某个站点未包括 <!DOCTYPE> 指令,则 Internet Explorer 6 将使用 Quirks 模式显示该站点。 如果某个站点包含有浏览器未能识别的有效 <!DOCTYPE> 指令,则 Internet Explorer 6 将使用 Internet Explorer 6 标准模式显示该站点。 由于已经包含 <!DOCTYPE> 指令的站点很少,因此兼容性模式切换极为成功。 这样使 Web 开发人员能够选择最佳时间将其站点迁移到标准模式。

随着时间的推移,许多站点都开始依赖标准模式。 这些站点同时还开始使用 Internet Explorer 6 的功能和行为来检测 Internet Explorer。 例如,Internet Explorer 6 并不支持 通用选择器(可能为英文网页);而某些网站将此用作为 Internet Explorer 提供特定内容的方式。

Internet Explorer 7 提供了通用选择器支持等新功能,旨在更全面地支持行业标准。 由于 <!DOCTYPE> 指令仅支持 Quirks 模式和标准模式这两种设置,因此 Internet Explorer 7 标准模式替换了 Internet Explorer 6 标准模式。

结果,依赖于 Internet Explorer 6 标准模式的行为的站点(如缺乏对通用选择器的支持)将无法检测到新版本的浏览器。 因此,Internet Explorer 特定的内容不会提供给 Internet Explorer 7,并且这些站点不会按预期显示。 由于 Internet Explorer 7 仅支持两种兼容性模式,因此将会迫使受影响站点的所有者更新其站点以支持 Internet Explorer 7。

与任何早期浏览器版本相比,Internet Explorer 8 对行业标准提供了更加紧密的支持。 因此,针对旧版本的浏览器设计的站点可能不会按预期显示。 为了帮助减轻任何问题,Internet Explorer 8 引入了文档兼容性的概念,从而允许您指定站点所支持的 Internet Explorer 版本。 文档兼容性在 Internet Explorer 8 中添加了新的模式;这些模式将告诉浏览器如何解释和呈现网站。 如果您的站点在 Internet Explorer 8 中无法正确显示,则可以更新该站点以支持最新的 Web 标准(首选方式),也可以强制 Internet Explorer 8 按照在旧版本的浏览器中查看站点的方式来显示内容。 通过使用 meta 元素将 X-UA-Compatible 标头添加到网页中,可以实现这一点。

这将允许您选择何时更新站点以支持由 Internet Explorer 8 支持的新功能。

了解文档兼容性模式

Internet Explorer 8 支持很多文档兼容性模式,这些模式启用不同的功能并可影响内容的显示方式。

  • “模仿 IE8”模式将告诉 Internet Explorer 使用 <!DOCTYPE> 指令来确定如何呈现内容。 标准模式指令将以 Internet Explorer 8 标准模式显示,而 Quirks 模式指令将以 IE5 模式显示。 与 IE8 模式不同,“模仿 IE8”模式遵循 <!DOCTYPE> 指令。

  • “模仿 IE7”模式将告诉 Internet Explorer 使用 <!DOCTYPE> 指令来确定如何呈现内容。 标准模式指令以 Internet Explorer 7 标准模式显示,而 Quirks 模式指令以 IE5 模式显示。 与 IE7 模式不同,“模仿 IE7 模式”遵循 <!DOCTYPE> 指令。 对于很多网站来说,这是首选的兼容性模式。

  • IE5 模式呈现内容的方式如同使用了 Internet Explorer 7 的 Quirks 模式来显示内容,这与 Internet Explorer 5 显示内容的方式非常相似。

  • 无论页面是否包含 <!DOCTYPE> 指令,IE7 模式呈现内容的方式均如同使用了 Internet Explorer 7 的标准模式来显示内容。

  • IE8 模式可最大程度地支持行业标准(包括 W3C 级联样式表级别 2.1 规范(可能为英文网页)  万维网链接 和 W3C 选择器 API(可能为英文网页)  万维网链接),并提供对 W3C 级联样式表级别 3 规范(工作草案)(可能为英文网页)  万维网链接 的有限支持。

  • Edge 模式将告诉 Internet Explorer 以可用的最高级别模式显示内容。 对于 Internet Explorer 8,这等同于 IE8 模式。 假设 Internet Explorer 的将来版本支持更高级别的兼容性模式,那么,设置为 Edge 模式的页面将以该版本支持的最高级别的模式显示。 当使用 Internet Explorer 8 查看时,这些相同的页面仍会以 IE8 模式显示。

由于 Edge 模式的文档使用查看网页所用的 Internet Explorer 版本可用的最高级别模式来显示网页,因此,建议仅将 Edge 模式用于测试页面和其他非生产活动。

指定文档兼容性模式

若要为网页指定文档模式,请使用 meta 元素,以在网页中包含 X-UA-Compatible  http-equiv 标头。 以下示例指定“模仿 IE7”模式兼容性。

<html>
<head>
  <!-- Mimic Internet Explorer 7 -->
  <meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" >
  <title>My Web Page</title>
</head>
<body>
  <p>Content goes here.</p>
</body>
</html> 

content 属性指定页面的模式;若要模仿 Internet Explorer 7 的行为,请指定“IE=EmulateIE7”。 指定“IE=5”、“IE=7”或“IE=8”可选择相应的兼容性模式。 还可以指定“IE=edge”以告诉 Internet Explorer 8 使用可用的最高级别模式。

X-UA-compatible 标头不区分大小写;不过,它必须显示在网页中除 title 元素和其他 meta 元素以外的所有其他元素之前的标头(HEAD 节(可能为英文网页))中。

配置 Web 服务器以指定默认兼容性模式

网站管理员可以通过定义站点的自定义标头,将其站点配置为默认采用特定的文档兼容性模式。 具体过程将依您的 Web 服务器而定。 例如,通过以下 web.config 文件,可以让 Microsoft Internet Information Services (IIS) 定义一个自定义标头,以便自动按照 IE7 模式呈现所有页面。

<?xml version="1.0" encoding="utf-8"?>
<configuration>
  <system.webServer>
    <httpProtocol>
      <customHeaders>
        <clear />
        <add name="X-UA-Compatible" value="IE=EmulateIE7" />
      </customHeaders>
    </httpProtocol>
  </system.webServer>
</configuration> 

如果使用 Web 服务器指定了默认的文档兼容性模式,则可通过在特定的网页中指定不同的文档兼容性模式来覆盖默认设置。 在网页中指定的模式优先于由 Web 服务器指定的模式。

有关如何指定自定义标头的信息,请查看特定的 Web 服务器的文档。 或者,访问以下网页以获取详细信息:

确定文档兼容性模式

若要确定使用 Internet Explorer 8 的网页的文本兼容性模式,请使用 document 对象的 documentMode 属性。 例如,将以下内容键入到 Windows Internet Explorer 8 的地址栏中,可显示当前网页的文档模式。

javascript:alert(document.documentMode);

documentMode 属性将返回一个与页面的文档兼容性模式相对应的数值。 例如,如果某个页面已选择支持 IE8 模式,则 documentMode 将返回值 8。

在 Internet Explorer 6 中引入的 compatMode 属性已被弃用,取而代之的是在 Internet Explorer 8 中引入的 documentMode 属性。当前依赖于 compatMode 的应用程序仍然可以在 Internet Explorer 8 中运行;但是,应将这些应用程序更新为使用 documentMode。

如果希望使用 JavaScript 来确定文档的兼容性模式,则应包含支持 Internet Explorer 旧版本的代码,如以下示例中所示。

engine = null;
if (window.navigator.appName == "Microsoft Internet Explorer")
{
   // This is an IE browser. What mode is the engine in?
   if (document.documentMode) // IE8
      engine = document.documentMode;
   else // IE 5-7
   {
      engine = 5; // Assume quirks mode unless proven otherwise
      if (document.compatMode)
      {
         if (document.compatMode == "CSS1Compat")
            engine = 7; // standards mode
      }
   }
   // the engine variable now contains the document compatibility mode.
}

了解 content 属性值

content 属性的使用很灵活,它可以接受除前面所述的值之外的值。 这样,您就能够更好地控制 Internet Explorer 显示网页的方式。 例如,可以将 content 属性设置为 IE=7.5。 当您如此设置之后,Internet Explorer 会尝试将该值转换为 版本矢量(可能为英文网页),并选择与转换结果最接近的模式。 在本例中,Internet Explorer 将会设置为 IE7 模式。 以下示例显示了为其他值选择的模式(如果不存在其他缓解因素)。

<meta http-equiv="X-UA-Compatible" content="IE=4">   <!-- IE5 mode -->
<meta http-equiv="X-UA-Compatible" content="IE=7.5" > <!-- IE7 mode -->
<meta http-equiv="X-UA-Compatible" content="IE=100" > <!-- IE8 mode -->
<meta http-equiv="X-UA-Compatible" content="IE=a" >   <!-- IE5 mode --> 

<!-- This header mimics Internet Explorer 7 and uses 
     <!DOCTYPE> to determine how to display the Web page -->
<meta http-equiv="X-UA-Compatible" content="IE=EmulateIE7" >    
注意  上一个示例显示了各个 content 值的结果。 实际上,Internet Explorer 仅遵循网页中的第一个 X-UA-Compatible 标头。

还可以使用 content 属性来指定多个文档兼容性模式;这将有助于确保网页在将来的浏览器版本中显示一致。 若要指定多个文档模式,应设置 content 属性以标识要使用的各个模式。 各个模式之间使用分号分隔。

如果某个特定的 Internet Explorer 版本支持多个请求的兼容性模式,则该版本将使用标头的 content 属性中列出的可用的最高级别模式。 可以利用这一原理来排除特定的兼容性模式,但不建议这样做。 例如,下面的标头排除了 IE7 模式。

<meta http-equiv="X-UA-Compatible" content="IE=5; IE=8" >

控制默认呈现

当 Internet Explorer 8 遇到未包含 X-UA-Compatible 标头的网页时,它将使用 <!DOCTYPE> 指令来确定如何显示该网页。 如果该指令丢失或未指定基于标准的文档类型,则 Internet Explorer 8 将以 IE5 模式(Quirks 模式)显示该网页。

如果 <!DOCTYPE> 指令指定了基于标准的文档类型,则 Internet Explorer 8 将以 IE8 模式显示该网页,但出现以下情况时除外:

  • 为该网页启用了兼容性视图。

  • 该网页是在 Intranet 区域中加载的,并且已将 Internet Explorer 8 配置为使用兼容性视图来显示 Intranet 区域中的网页。

  • 已将 Internet Explorer 8 配置为使用兼容性视图来显示所有网站。

  • 已将 Internet Explorer 8 配置为使用兼容性视图列表(其中指定了一组始终使用兼容性视图显示的网站)。

  • 已使用开发人员工具覆盖在该网页中指定的设置。

  • 该网页遇到了页面布局错误,并且已将 Internet Explorer 8 配置为,通过在兼容性视图中重新打开网页来自动从此类错误中恢复。

有关详细信息,请参见 Internet Explorer 博客: 兼容性视图概述(可能为英文网页)  万维网链接

注意  如果将 Internet Explorer 配置为使用兼容性视图加载 Intranet 页面,Internet Explorer 将对使用 localhost 地址或 环回地址(可能为英文网页)加载的页面引发异常。 如果 <!DOCTYPE> 指令指定基于标准的文档类型,则将以 IE8 模式显示使用这些技术加载的页面。

此外,可以使用下面的注册表项来控制 Internet Explorer 对未包含 X-UA-Compatible 标头的页面的处理方式。

HKEY_LOCAL_MACHINE (or HKEY_CURRENT_USER)
     SOFTWARE
          Microsoft
               Internet Explorer
                    Main
                         FeatureControl
                              FEATURE_BROWSER_EMULATION
                                   iexplore.exe = (DWORD)

DWORD 值必须等于下列值之一。

说明
7000 包含基于标准的 <!DOCTYPE> 指令的页面将以 IE7 模式显示。
8000 包含基于标准的 <!DOCTYPE> 指令的页面以 IE8 模式显示。
8888 页面始终以 IE8 模式显示,而不考虑 <!DOCTYPE> 指令。 (这可绕过前面列出的例外情况。)

默认情况下,承载 WebBrowser 控件(可能为英文网页)的应用程序将以 IE7 模式打开基于标准的页面,除非页面中包含适当的 X-UA-Compatible 标头。 通过将应用程序可执行文件的名称添加到 FEATURE_BROWSER_EMULATION 功能控制项中,并相应地设置值,可以更改打开模式。

总结

对于 Web 设计人员来说,兼容性是一个要考虑的重要问题。 尽管最好是创建不依赖于 Web 浏览器的特定行为或功能的站点,但有时这样做是不可能的。 文档兼容性模式将网页与 Internet Explorer 特定版本的行为相关联。

使用 X-UA-Compatible 标头可指定页面支持的 Internet Explorer 版本。 使用 document.documentMode 可确定网页的兼容性模式。

通过选择支持特定的 Internet Explorer 版本,可有助于确保页面在将来的浏览器版本中能够显示一致。

分享到:
评论
1 楼 tpsnake 2012-06-19  
帮助很大,非常感谢,好贴一生要顶

相关推荐

    jsp浏览器的兼容性

    background 和 background-color 的兼容性不同,background-color 被 IE、360、百度浏览器识别,而 FF 和谷歌浏览器对其识别性较差。 9.关于手形光标 在设置光标样式时,需要注意 cursor: pointer 是通用的,而 ...

    MFC实现IE浏览器

    MFC本身并不直接支持浏览器功能,但我们可以利用其窗口、消息处理和控件等机制,结合ActiveX技术,来嵌入IE浏览器组件(即WebBrowser控件)。WebBrowser控件是微软提供的一种ActiveX控件,它内置了IE的浏览功能,...

    IE7.JS解决IE兼容性问题方法

    1. **JavaScript库**:IE7.js是一个JavaScript代码集合,设计用于在旧版IE浏览器中添加新特性和功能。它不是实际更新浏览器的软件,而是在用户端运行的脚本,可以通过在HTML文件中引入该脚本来应用。 2. **浏览器...

    解决IE6兼容问题的十一大技巧

    2. **CSS选择器的兼容性**:IE6不支持子选择器,如`div &gt; p`。为了解决这个问题,可以先为IE6编写普通CSS选择器,然后使用子选择器针对其他更现代的浏览器。例如: ```css /* IE6 专用 */ .content {color:red;} ...

    C#操作IE浏览器

    ### C#操作IE浏览器知识点详解 #### 一、概述 在C#中操作IE浏览器主要涉及到几个关键步骤:获取IE窗口句柄、控制IE窗口的行为(如最大化)、以及读取网页的内容(例如HTML源码)。本文将围绕这些核心点进行详细...

    IE和Firefox的Javascript兼容性总结[定义].pdf

    - 事件注册:IE使用`attachEvent`,非IE浏览器使用`addEventListener`。要兼容所有浏览器,需为每个事件添加两种注册方法。 - 事件冒泡和捕获:IE默认事件冒泡,Firefox等支持捕获。理解事件模型并适配处理是必要...

    浏览器兼容性CSS,IE6,IE7,FF

    本文主要针对IE6、IE7和Firefox(FF)这三种浏览器的CSS兼容性进行详解。 首先,我们来看一下如何处理CSS兼容性问题。一种常用的方法是利用CSS Hack,即针对特定浏览器添加特定的样式规则。例如,对于`height`属性...

    IE浏览器校验dtd文件小插件(含使用说明)

    3. **兼容性**:Iexmltls专门针对IE浏览器优化,确保在各种版本的IE中都能稳定运行,满足不同用户需求。 4. **提升效率**:通过自动化验证,减少了人工检查的时间和精力,特别是在处理大量XML文档时,效率提升显著...

    stickyheaderjs是一款非常实用的兼容IE8浏览器的页面顶部固定jQuery插件

    Sticky-headerjs 是一个专为此目的而设计的jQuery插件,特别强调了对老版本IE浏览器(如IE8)的良好兼容性,这在当前仍然需要支持较旧浏览器的项目中显得尤为宝贵。 Sticky-header.js插件的工作原理是监听用户的...

    webbrowser仿ie浏览器缩放功能绝对完美

    ### WebBrowser 控件实现IE浏览器缩放功能详解 在开发基于.NET Framework的应用程序时,有时候我们需要集成一些浏览器的功能,例如浏览网页、填充表单、甚至实现网页缩放等功能。本篇将详细介绍如何利用C#中的`...

    img图片在ie下有有空隙

    - **IE特有的CSS Hack**:对于特定版本的IE浏览器,还可以尝试使用CSS Hack来针对性地解决兼容性问题。 #### 结论 综上所述,IE浏览器下图片周围出现空隙的问题可以通过调整CSS样式轻松解决。推荐使用 `float: left...

    IE小窗口代码

    因此,这个代码可能包含了一些针对IE浏览器特性的兼容性处理。 在“压缩包子文件的文件名称列表”中,我们只有一个文件名:`IE小窗口代码`。这个文件可能包含了一个HTML文件,用于展示小窗口的效果;一个JavaScript...

    让IE浏览器支持HTML5标准的方法.docx

    总之,为了让IE浏览器支持HTML5,可以使用JavaScript代码创建新元素,或者通过升级浏览器版本来获取更好的HTML5兼容性。随着HTML5标准的逐步完善和浏览器厂商的不断努力,未来的网络环境将更加友好,HTML5的潜力将...

    捕获IE

    在IT行业中,"捕获IE"通常指的是对Internet Explorer(IE)浏览器的...请注意,由于IE浏览器的安全性和兼容性问题,现代Web开发更多地转向了其他浏览器和前端框架,但这些技术对于理解旧系统或特定场景仍然很有价值。

    浏览器兼容性问题大汇总

    浏览器兼容性问题一直是前端开发者面临的重要挑战。本文将深入探讨其中的部分问题,帮助开发者更好地理解和解决这些问题。 1. JavaScript 问题: - HTML 对象获取:在 FireFox 中,应始终使用 `document....

    深入理解指定IE浏览器渲染方式

    IE浏览器作为早期广泛使用的网页浏览器,由于其在渲染网页时经常出现兼容性问题,成为了前端设计师和开发人员的一大难题。IE浏览器中的渲染方式指的是浏览器解析HTML和CSS以及执行JavaScript的内部机制,而这些机制...

    event兼容调用(IE,Firefox,Chrome)

    此段代码会在非IE浏览器上动态定义`window.event`的getter,使其能够追踪当前执行栈中最近的一次事件调用,从而返回正确的事件对象。 #### 鼠标坐标获取的兼容性 另一个常见的兼容性问题是获取鼠标坐标。在不同...

    vue自定义浏览器滚动条(兼容大部分浏览器含ie)_vue tree组件 下拉滚动条

    这些库通过JavaScript实现滚动条的自定义,并且已经处理了浏览器兼容性问题。以`simple-scrollbar`为例,我们首先需要在项目中安装它: ```bash npm install simple-scrollbar --save ``` 然后在Vue组件中引入并...

Global site tag (gtag.js) - Google Analytics