关于IE浏览器的mode

IE浏览器从IE8开始新增了一个获取的文档模式(document mode)属性:documentMode。

一般的获取文档模式可以这么写: var mode= document.documentMode;

它在各个IE浏览器下的值如下表:

浏览器版本 IE6 IE7 IE8 IE8兼容模式 IE9 IE9兼容模式 IE10 IE10兼容模式
undefined undefined 8 7 9 7 or 8 10 7 or 8 or 10

 

 

 

除此之外,在IE的怪异模式(Quirks Mode)下,document.documentMode==5。

以前,我通过JavaScript取得浏览器的版本号的时候,用的是如下方法

复制代码
//get IE version.
//if not IE ,return 0
function getIEVersion() {
    var ua = navigator.userAgent; 
    var version = ua.indexOf("MSIE "); 
    if (version < 0) {
        return 0;
    }
    return parseFloat(ua.substring(version + 5, ua.indexOf(";", version)));
}
复制代码

后来在一次项目中,发现根据上面取得浏览器版本,设置页面的时候没起到效果。这才发现【文档模式】这个玩意儿。

如果我们在jsp中加入如下代码:

<meta http-equiv="x-ua-compatible" content="IE=8;" />

然后我们用IE7来打开这个页面,通过getIEVersion()方法取到的结果依然是7

但是实际上取到的documentMode为8,而页面也是按照IE8模式去解析的。

 

于是乎有网友提供了如下判断IE版本的办法:

var ieMode=document.documentMode;
var isIE=!!window.ActiveXObject;
var isIE6=isIE&&!window.XMLHttpRequest;
var isIE7=isIE&&!isIE6&&!ieMode||ieMode==7;
var isIE8=isIE&&ieMode==8;
var isIE9=isIE&&ieMode==9;
var isIE10=isIE&&ieMode==10;

 

与documentMode相关联的还有一个compatMode属性。

compatMode属性的唯一使命就是:表示浏览器处于什么模式。

如果是标准模式,则document.compatMode的值等于“CSS1Compat”
如果是怪异模式,则document.compatMode的值等于“BackCompat”

 

 

参考资料:

http://yiminghe.iteye.com/blog/802021

 

 

 

posted @   yejg1212  阅读(318)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
点击右上角即可分享
微信分享提示