zoukankan      html  css  js  c++  java
  • 前端开发工程师:不是IE的IE11(转载)

    IE11浏览器自去年六月份发布以来虽然据说也取得了不错的成绩,但是根据百度流量研究院的浏览器数据显示,国内好像还看不到其占有率,但全球范围内IE11的占有率已经超过IE10和IE9的总和。获取IE11可以从两种方式:安装 Win8.1 里面内置IE11;从Win 7的 IE9/10 升级,但XP在中国仍然有超过60%的占有率,而XP最高也只能升级到IE8。

    前端测试仍在徘徊在IE6 ~ IE10之间,但在开发过程中偶然间发现了IE11与众IE不同之处。

    前端开发一直将浏览器分为 W3C 和 IE 两种,特别是将 IE 众版本当做异类对待。微软这次决定洗心革面,将 IE11 打造成一款不是“IE”的浏览器,拥有与其它“W3C”浏览器一样的特性。

    重要变动

    IE11 支持了完整的 flex 能力(参见利用flexbox构建可伸缩布局),于 Firefox 之后第二个拥有无前缀 CSS 属性名。

    支持了 SPDY 协议。

    ActiveXObject 对象不再存在了,这使得许多依靠检测该对象来嗅探浏览器类型的代码失效。

    同样,document.all 的布尔值也会返回 false 。许多浏览器拥有该对象但是在转成布尔值时故意返回 false 用以兼容之前无数使用该对象判断浏览器类型的代码。现在,只有 IE6~IE9 会返回 true。

    UA中一直存在的 MSIE 被删除,依赖于此获取浏览器类型和版本号的代码将失效。要判断其类型和版本,必须MSIE 和 Trident 共用了。

    溢出了 attachEvent ,以 addEventListener 取代之,这也会破坏使用该方法判断浏览器类型的代码。

    IE8 引入的 XDomainRequest 被删除,取而代之的是支持跨域资源共享(CORS)的 XMLHttpRequest。

    总结

    显然 IE11 的改进破坏了几乎所有用于区分 W3C 和 IE 浏览器的方法,使得无数现存代码无法取得其是 IE 浏览器的事实。或许这就是微软的目的:IE11 不再是“IE”了,你不需要在判断出来它了。

    下面给出使用 UA 获取 IE 版本的代码:

    /**
     * Get version if it's a microsoft internet explorer.
     *
     * @return version code,or else null if it's not a IE.
     */
    function getIEVersion(){
        var ua = navigator.userAgent,matches,tridentMap={'4':8,'5':9,'6':10,'7':11};
    
        matches = ua.match(/MSIE (d+)/i);
    
        if(matches&&matches[1])
        {
            //find by msie
            return +matches[1];
        }
    
        matches = ua.match(/Trident/(d+)/i);
        if(matches&&matches[1])
        {
            //find by trident
            return tridentMap[matches[1]]||null;
        }
    
        //we did what we could
        return null;
    }
    

    由于 UA 可以随意伪造,所以并没有合适的方法能够保证检测出真正的浏览器环境,因此代码都不应依赖于具体的环境和版本。

  • 相关阅读:
    C# 之 获取文件名及拓展名
    C# 之 日常积累(二)
    C# 之 OpenFileDialog的使用
    Linux系统中,main函数的执行过程
    linux线程的实现
    linux内核--进程与线程
    内核线程和进程的区别
    软中断和硬中断
    Linux 2.4.x内核软中断机制
    几种USB控制器类型:OHCI,UHCI,EHCI,xHCI
  • 原文地址:https://www.cnblogs.com/hzwl-2015/p/4794986.html
Copyright © 2011-2022 走看看