zoukankan      html  css  js  c++  java
  • 关于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

  • 相关阅读:
    解析网页源码方式
    vue踩坑--细节决定成败
    fallowing-travelvue
    学会不怕
    eslint代码规范检测
    三次握手+四次挥手
    小白的学习笔记
    es6数组
    css知识整理
    JavaScript之事件循环,宏任务与微任务
  • 原文地址:https://www.cnblogs.com/yejg1212/p/3073326.html
Copyright © 2011-2022 走看看