欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Internet Explorer 11 瀏覽器介紹:別叫我IE

 更新時間:2014年09月28日 23:25:21   作者:前端開發(fā)  
這篇文章主要介紹了Internet Explorer 11 瀏覽器介紹:別叫我IE,需要的朋友可以參考下

在上個星期,微軟隨Windows 8.1正式推出了Internet Explorer 11的第一次預覽版。這樣,關(guān)于這款備受爭議的web瀏覽器泄露版本的各種傳聞也該休息了。我們現(xiàn)在已經(jīng)知道一些關(guān)于Internet Explorer 11的重要的細節(jié),包括支持WebGL ,prefetch(譯者注:預讀取,比如上傳文件的預覽啥的,不知道翻譯的對不對),prerender(預呈現(xiàn)), flexbox,mutation observers和其他web標準,也許在IE11中更有趣的是,它是不是IE。

長期以來,微軟第一次從Internet Explorer瀏覽器中移除了一些特征。user-agent字符串也更改了。看來,微軟已經(jīng)拋棄了自己的方式,這樣現(xiàn)有的檢測IE的代碼分支在Internet Explorer 11瀏覽器中都將返回false,無論是在 javascript里還是服務器上。

User-agent的改變

相對于以前的版本,Internet Explorer 11的user-agent字符串更短,而且還有一些有意思的變化:

復制代碼 代碼如下:

Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv 11.0) like Gecko

對于在Windows 7上Internet Explorer 10的user-agent字符串

復制代碼 代碼如下:

Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)

最明顯的區(qū)別是,一直存在Internet Explorer瀏覽器user-agent字符串的“MSIE”標記去掉了。同樣引人注目的是在user-agent的尾部添加了“l(fā)ike Gecko”。這表明Internet Explorer寧可被識別為Gecko瀏覽器,也不愿被識別為Internet Explorer自己。Safari是第一個添加“l(fā)ike Gecko”的瀏覽器,這樣任何人都可以嗅探user-agent字符串里面的“Gecko”字符允許瀏覽器通過。

現(xiàn)在任何查找“MSIE”的嗅探代碼在新的user-agent字符串下不能工作。你仍然可以搜索“Trident”字符來確定它是IE瀏覽器(“Trident”標識是隨著Internet Explorer推出來的)。Internet Explorer的真正版本通過“rv”來標識。

此外,navigator對象的信息也有一些變化,這樣更掩飾了正在使用的瀏覽器的。

navigator.appName 被設置為“Netscape”
navigator.product被設置為 “Gecko”

這可能看起來像企圖偷偷摸摸欺騙開發(fā)人員,但是這些實際上是HTML5指定的。navigator.product屬性必須為“Gecko”,同時navigator.appName也應該是“Netscape”或者更具體的。但Internet Explorer 11缺遵循了這個奇怪的建議。

navigator信息的更改導致的副作用,正在使用的基于Javascript邏輯的瀏覽器檢測將可能無法使用,導致 Internet Explorer 11識別為基于Gecko的瀏覽器。

document.all和他的朋友們

從IE4以來,document.all在IE瀏覽器中無所不能。此前實行的document.getElementById()類似,document.all是得到一個DOM元素引用的IE方式。盡管從IE5開始到IE10,document.all都保持著對 DOM的支持。然而在11中,這個時代遺留下來的產(chǎn)物已經(jīng)被設置為返回false,這就意味著任何基于document.all的代碼分支判斷在IE11中將失敗,即使代碼實際使用document.all能正常工作。

另一個遺留是添加事件函數(shù)的attachEvent(),類似于detachEvent()方法。這個方法已經(jīng)從IE11中移除了。移除這些方法,是為了避免一些邏輯判斷,比如:

復制代碼 代碼如下:

function addEvent(element, type, handler) {
    if (element.attachEvent) {
        element.attachEvent("on" + type, handler);
    } else if (element.addEventListener) {
        element.addEventListener(type, handler, false);
    }
}

當然,我們推薦你最好用來測試的版本是一直穩(wěn)定,符合標準的。在某種層面上說,移除attachEvent方法不會產(chǎn)生任何地不適應。然而,互聯(lián)網(wǎng)充斥著槽糕的特征檢測邏輯代碼。attachEvent方法的刪除確保任何以上述方式編寫的代碼將使用標準的版本,取代IE特有的方法。

其他一些被移除的特征:

window.execScript()——eval()方法的IE版本

window.doScroll()——IE窗口的滾動方法
script.onreadystatechange——IE中監(jiān)聽加載腳本的狀態(tài)更改
script.readyState——IE中腳本加載的狀態(tài)
document.selection——IE中當前選中的文本
document.createStyleSheet——IE中創(chuàng)建樣式表文擋
style.styleSheet——IE瀏覽器中引用一個樣式表的樣式對象
所有這些IE瀏覽器的方式都被標準的特征所取代。在移除這些特征和方法后,基于標準功能特征檢測的跨瀏覽器代碼在不改變的情況下依然可以正常運行。

結(jié)論
在很長的時間段內(nèi),IE11可能是最好的IE瀏覽器。微軟終于開始準備消除過去犯的錯誤,準備開始從包括基于現(xiàn)在標準的瀏覽器做起。刪除舊的特征和修改不被認定為IE瀏覽器的用戶代理字符串是一個很獨特的做法,它確保所有的網(wǎng)站能繼續(xù)工作。如果Web應用程序使用功能檢測,而不是瀏覽器嗅探,那么代碼應該可以IE11中運行。對于使用user-agent嗅探的應用,用戶仍然能看到一個功能完好的網(wǎng)站,因為IE11對標準支持的十分優(yōu)秀。

一個沒有IE分支代碼的未來即將到來,讓我們一起期待。

(2013-7-2更新),修訂提到的document.all實際上并未刪除,而改為falsy

好久沒翻譯文章了,這次翻譯的是 Nicholas C. Zakas大牛的Blog,
原文在這:http://www.nczonline.net/blog/2013/07/02/internet-explorer-11-dont-call-me-ie/

相關(guān)文章

  • 薦書|您有一份JavaScript書單待簽收

    薦書|您有一份JavaScript書單待簽收

    ​學習是一個持續(xù)不斷的過程,在互聯(lián)網(wǎng)技術(shù)里暢游的程序員們,對學習的渴望更是難以窮盡,下面這篇文章主要給大家分享了關(guān)于Javascript相關(guān)的書籍,對大家學習Javascript具有一定的參考學習價值,下面來一起看看吧。
    2017-07-07
  • JavaScript匿名函數(shù)與委托使用示例

    JavaScript匿名函數(shù)與委托使用示例

    本例主要介紹了JavaScript匿名函數(shù)與委托的使用,需要的朋友可以參考下
    2014-07-07
  • Javascript的閉包詳解

    Javascript的閉包詳解

    這篇文章主要介紹了Javascript的閉包詳解,需要的朋友可以參考下
    2014-12-12
  • JavaScript面向?qū)ο笾甤lass繼承類案例講解

    JavaScript面向?qū)ο笾甤lass繼承類案例講解

    這篇文章主要介紹了JavaScript面向?qū)ο笾甤lass繼承類案例講解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Google Dart編程語法和基本類型學習教程

    Google Dart編程語法和基本類型學習教程

    Dart編程語言是一個完全面向?qū)ο蟮恼Z言,包括基礎類型如int變量也都是對象,本文主要介紹了Google Dart編程語法和基本類型
    2013-11-11
  • Javascript中的幾種繼承方式對比分析

    Javascript中的幾種繼承方式對比分析

    下面小編就為大家?guī)硪黄狫avascript中的幾種繼承方式對比分析。小編覺得挺不錯的,現(xiàn)在分享給大家,希望能給大家一個參考。一起跟隨小編過來看看吧
    2016-03-03
  • JS對象與JSON互轉(zhuǎn)換、New Function()、 forEach()、DOM事件流等js開發(fā)基礎小結(jié)

    JS對象與JSON互轉(zhuǎn)換、New Function()、 forEach()、DOM事件流等js開發(fā)基礎小結(jié)

    這篇文章主要介紹了JS對象與JSON互轉(zhuǎn)換、New Function()、 forEach()、DOM事件流等js開發(fā)中基礎的知識點,并通過舉例詳細解釋了JavaScript定義的數(shù)據(jù)類型、無第三變量交換值、/和%運算符、Memoization技術(shù)、閉包等知識,需要的朋友可以參考下
    2017-08-08
  • caller和callee的區(qū)別介紹及演示結(jié)果

    caller和callee的區(qū)別介紹及演示結(jié)果

    caller返回一個函數(shù)的引用,這個函數(shù)調(diào)用了當前的函數(shù);callee放回正在執(zhí)行的函數(shù)本身的引用,它是arguments的一個屬性,感興趣的你可以參考下或許可以幫助到你
    2013-03-03
  • 取得父標簽

    取得父標簽

    取得父標簽...
    2006-11-11
  • Javascript Global對象

    Javascript Global對象

    Global對象是ECMAScript中最特別的對象,因為實際上它根本不存在。
    2009-08-08

最新評論