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

JS如何判斷是否為ie瀏覽器的方法(包括IE10、IE11在內(nèi))

 更新時間:2021年07月26日 23:58:42   投稿:mdxy-dxy  
這篇文章主要介紹了JS如何判斷是否為ie瀏覽器的方法(包括IE10、IE11在內(nèi)),需要的朋友可以參考下

今天在寫一個代碼復制功能的時候,發(fā)現(xiàn)的這個問題,ie11也不支持document.all,看來以后越來越標準了

今天碰到一個奇怪的問題,有一個頁面,想指定用IE瀏覽器打開,在VS開發(fā)環(huán)境沒有問題,但部署到服務器上,即使是用IE打開頁面,還是提示“僅支持IE”,真是暈?。?!
判斷是否IE瀏覽器用的是window.navigator.userAgent,跟蹤這個信息,發(fā)現(xiàn)在開發(fā)環(huán)境,識別為IE10,但訪問服務器則識別為IE11,但IE11的userAgent里是沒有MSIE標志的,原因就是這個了。

把判斷IE瀏覽器的方法改成如下就可以了。

原來的函數(shù)寫法:對于新版的ie11已經(jīng)不支持了

function isIE(){
if (window.navigator.userAgent.indexOf("MSIE")>=1) 
return true; 
else 
return false; 
}

ie10及以上不支持ie瀏覽器的判斷了,因為ie11已經(jīng)不支持document.all了,下面是支持ie11的版本的,當然ie6-8也是支持的

function isIE() { //ie?
 if (!!window.ActiveXObject || "ActiveXObject" in window)
  return true;
  else
  return false;
 }

判斷IE瀏覽器的具體版本

function IEVersion() {
      var userAgent = navigator.userAgent; //取得瀏覽器的userAgent字符串  
      var isIE = userAgent.indexOf("compatible") > -1 && userAgent.indexOf("MSIE") > -1; //判斷是否IE<11瀏覽器  
      var isEdge = userAgent.indexOf("Edge") > -1 && !isIE; //判斷是否IE的Edge瀏覽器  
      var isIE11 = userAgent.indexOf('Trident') > -1 && userAgent.indexOf("rv:11.0") > -1;
      if(isIE) {
          var reIE = new RegExp("MSIE (\\d+\\.\\d+);");
          reIE.test(userAgent);
          var fIEVersion = parseFloat(RegExp["$1"]);
          if(fIEVersion == 7) {
              return 7;
          } else if(fIEVersion == 8) {
              return 8;
          } else if(fIEVersion == 9) {
              return 9;
          } else if(fIEVersion == 10) {
              return 10;
          } else {
              return 6;//IE版本<=7
          }   
      } else if(isEdge) {
          return 'edge';//edge
      } else if(isIE11) {
          return 11; //IE11  
      }else{
          return -1;//不是ie瀏覽器
      }
  }

JS通過內(nèi)核判斷各種瀏覽器|區(qū)分360與谷歌(現(xiàn)在不能用了曾經(jīng)可以用)

function getBrowserInfo(){
        var ua = navigator.userAgent.toLocaleLowerCase();
        var browserType=null;
        if (ua.match(/msie/) != null || ua.match(/trident/) != null) {
            browserType = "IE";
            browserVersion = ua.match(/msie ([\d.]+)/) != null ? ua.match(/msie ([\d.]+)/)[1] : ua.match(/rv:([\d.]+)/)[1];
        } else if (ua.match(/firefox/) != null) {
            browserType = "火狐";
        }else if (ua.match(/ubrowser/) != null) {
            browserType = "UC";
        }else if (ua.match(/opera/) != null) {
            browserType = "歐朋";
        } else if (ua.match(/bidubrowser/) != null) {
            browserType = "百度";
        }else if (ua.match(/metasr/) != null) {
            browserType = "搜狗";
        }else if (ua.match(/tencenttraveler/) != null || ua.match(/qqbrowse/) != null) {
            browserType = "QQ";
        }else if (ua.match(/maxthon/) != null) {
            browserType = "遨游";
        }else if (ua.match(/chrome/) != null) {
            var is360 = _mime("type", "application/vnd.chromium.remoting-viewer");
            function _mime(option, value) {
                var mimeTypes = navigator.mimeTypes;
                for (var mt in mimeTypes) {
                    if (mimeTypes[mt][option] == value) {
                        return true;
                    }
                }
                return false;
            }
            if(is360){
                browserType = '360';
            }else{
                $('html').css("zoom",".80");
            }
        }else if (ua.match(/safari/) != null) {
            browserType = "Safari";
        }
}

只有原生Chrome中存在一種MimeType“application/vnd.chromium.remoting-viewer”,由此可以判斷瀏覽器是加殼Chrome或是原生Chrome。
再如,只有IE內(nèi)核的瀏覽器存在ActiveXObject對象。由此可以判斷是否為IE瀏覽器

判斷瀏覽器類型,我們需要遵循以下原則:
1、采取命中特征原則,當且僅當完全符合區(qū)分瀏覽器的特征時我們才會采用此特征。例如單純通過UA中MSIE來檢測是否為IE瀏覽器是不可靠的。而通過判斷是否存在MimeType“application/vnd.chromium.remoting-viewer”來斷言原生Chrome在現(xiàn)階段來看是可行性,但也不保證永久有效。
2、對于主流瀏覽器來說一般不存在UserAgent關(guān)鍵字沖突,但對于許多加殼瀏覽器者就不一定了。再次提出某數(shù)字瀏覽器,userAgent干脆和IE一模一樣,但渲染模式等等不不知道動了什么手腳,與標準IE行為差異很大。通過userAgent來判斷瀏覽器時,優(yōu)先命中瀏覽器特征字。匹配則基本確定為該瀏覽器,但未匹配也并不代表不是此瀏覽器。請悉知。
3、優(yōu)先使用瀏覽器特性來區(qū)分瀏覽器,因為這個準確性較高。其次再采用userAgent輔助判斷,從而達到最高的匹配度。
4、優(yōu)先檢測第三方加殼瀏覽器,目前并未有十分好的方案,只能枚舉大部分世面上存在并可以判斷的瀏覽器,其他未匹配任何規(guī)則的瀏覽器,為了兼容,請將規(guī)則落到四大瀏覽器之一。
5、判斷瀏覽器版本,僅僅是為了針對特定瀏覽器進行優(yōu)化,需要有特定的業(yè)務場景需要才要這么做?;蛘弋斈硞€瀏覽器出現(xiàn)兼容問題時,緊急添加針對瀏覽器的補丁代碼時才判斷。更加科學穩(wěn)妥的辦法是使用標準的JS函數(shù)和API,頁面元素和樣式設計遵循W3C標準。可能存在爭議的兼容性問題盡可能采用第三方框架如jQuery。這才是解決兼容性問題的根本。

相關(guān)文章

  • JavaScript 解決ajax中parsererror錯誤案例詳解

    JavaScript 解決ajax中parsererror錯誤案例詳解

    這篇文章主要介紹了JavaScript 解決ajax中parsererror錯誤案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • js實現(xiàn)簡單的手風琴效果

    js實現(xiàn)簡單的手風琴效果

    本文主要介紹了js實現(xiàn)簡單手風琴效果的實例,具有很好的參考價值,下面跟著小編一起來看下吧
    2017-02-02
  • javascript 設計模式之組合模式原理與應用詳解

    javascript 設計模式之組合模式原理與應用詳解

    這篇文章主要介紹了javascript 設計模式之組合模式原理與應用,結(jié)合實例形式分析了javascript組合模式基本概念、原理、應用場景及操作注意事項,需要的朋友可以參考下
    2020-04-04
  • webpack之引入圖片的實現(xiàn)及問題

    webpack之引入圖片的實現(xiàn)及問題

    如果我們希望在頁面引入圖片。當我們基于webpack進行開發(fā)時,引入圖片會遇到一些問題,這篇文章主要介紹了webpack之引入圖片的實現(xiàn)及問題,非常具有實用價值,需要的朋友可以參考下
    2018-10-10
  • JS關(guān)鍵字變色實現(xiàn)思路及代碼

    JS關(guān)鍵字變色實現(xiàn)思路及代碼

    JS關(guān)鍵字變色詳細很多朋友都很想實現(xiàn)吧接下來將執(zhí)行以下幾個步驟:1.替換關(guān)鍵字,對字體變色2.用正則,CSS背景變色;該方法可結(jié)合前臺JS調(diào)用,感興趣的朋友可以參考下,希望可以幫助到你
    2013-02-02
  • JS 動態(tài)判斷PC和手機瀏覽器實現(xiàn)代碼

    JS 動態(tài)判斷PC和手機瀏覽器實現(xiàn)代碼

    這篇文章主要介紹了JS 動態(tài)判斷PC和手機瀏覽器實現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • 關(guān)于Iframe父頁面與子頁面之間的相互調(diào)用

    關(guān)于Iframe父頁面與子頁面之間的相互調(diào)用

    下面小編就為大家?guī)硪黄P(guān)于Iframe父頁面與子頁面之間的相互調(diào)用。小編覺得挺不錯的,希望對大家有所幫助。一起跟隨小編過來看看吧,祝大家游戲愉快哦
    2016-11-11
  • 微信小程序引入VANT組件的方法步驟

    微信小程序引入VANT組件的方法步驟

    這篇文章主要介紹了微信小程序引入VANT組件的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-09-09
  • JS實現(xiàn)鼠標滑過折疊與展開菜單效果代碼

    JS實現(xiàn)鼠標滑過折疊與展開菜單效果代碼

    這篇文章主要介紹了JS實現(xiàn)鼠標滑過折疊與展開菜單效果代碼,涉及JavaScript基于鼠標事件動態(tài)改變頁面元素樣式的相關(guān)實現(xiàn)技巧,非常具有實用價值,需要的朋友可以參考下
    2015-09-09
  • JavaScript實現(xiàn)shuffle數(shù)組洗牌操作示例

    JavaScript實現(xiàn)shuffle數(shù)組洗牌操作示例

    這篇文章主要介紹了JavaScript實現(xiàn)shuffle數(shù)組洗牌操作,結(jié)合實例形式分析了javascript數(shù)組的定義、構(gòu)造、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01

最新評論