js判斷操作系統與瀏覽器

来源:http://www.cnblogs.com/shouce/archive/2016/01/15/5132238.html
-Advertisement-
Play Games

摘要: 對於前端開發我們最重要的工作就是相容性,系統的相容性,瀏覽器的相容性等等。今天分享一個我在項目中封裝的判斷操作系統與瀏覽器的方法。操作系統:var os = (function() { var UserAgent = navigator.userAgent.toLowerCase()...


摘要:

  對於前端開發我們最重要的工作就是相容性,系統的相容性,瀏覽器的相容性等等。今天分享一個我在項目中封裝的判斷操作系統與瀏覽器的方法。

操作系統:

複製代碼
var os = (function() {
    var UserAgent = navigator.userAgent.toLowerCase();
    return {
        isIpad          : /ipad/.test(UserAgent),
        isIphone        : /iphone os/.test(UserAgent),
        isAndroid       : /android/.test(UserAgent),
        isWindowsCe     : /windows ce/.test(UserAgent),
        isWindowsMobile : /windows mobile/.test(UserAgent),
        isWin2K         : /windows nt 5.0/.test(UserAgent),
        isXP            : /windows nt 5.1/.test(UserAgent),
        isVista         : /windows nt 6.0/.test(UserAgent),
        isWin7          : /windows nt 6.1/.test(UserAgent),
        isWin8          : /windows nt 6.2/.test(UserAgent),
        isWin81         : /windows nt 6.3/.test(UserAgent),
isMac : /mac os/.test(UserAgent) }; }());
複製代碼

 

如果要判斷系統是否是iPad,只需要判斷if(os.isIpad) {}.

瀏覽器:

 

複製代碼
var bw = (function() {
    var UserAgent = navigator.userAgent.toLowerCase();
    return {
        isUc      : /ucweb/.test(UserAgent), // UC瀏覽器
        isChrome  : /chrome/.test(UserAgent.substr(-33,6)), // Chrome瀏覽器
        isFirefox : /firefox/.test(UserAgent), // 火狐瀏覽器
        isOpera   : /opera/.test(UserAgent),  // Opera瀏覽器
        isSafire  : /safari/.test(UserAgent) && !/chrome/.test(UserAgent), // safire瀏覽器
        is360     : /360se/.test(UserAgent), // 360瀏覽器
        isBaidu   : /bidubrowser/.test(UserAgent), // 百度瀏覽器
        isSougou  : /metasr/.test(UserAgent), // 搜狗瀏覽器
        isIE6     : /msie 6.0/.test(UserAgent), // IE6
        isIE7     : /msie 7.0/.test(UserAgent), // IE7
        isIE8     : /msie 8.0/.test(UserAgent), // IE8
        isIE9     : /msie 9.0/.test(UserAgent), // IE9
        isIE10    : /msie 10.0/.test(UserAgent), // IE10
        isIE11    : /msie 11.0/.test(UserAgent), // IE11
        isLB      : /lbbrowser/.test(UserAgent), // 獵豹瀏覽器
     isWX      : /micromessenger/.test(UserAgent), // 微信內置瀏覽器
        isQQ      : /qqbrowser/.test(UserAgent) // QQ瀏覽器
    };
}());
複製代碼

 

小結:

  瀏覽器都是本人親自測試的,可能會有問題的是chrome瀏覽器,因為大部分瀏覽器都是使用WebKit內核,所以我就把chrome的navigator截取出來區分。如果以後chrome的navigator的信息位置或者chrome之後的長度發生改變就容易出現問題,但目前來看是可以的。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、面向對象1.1java鍵盤輸入 1.1.1這種方法我認為是最簡單,最強大的,就是用Scanner類import java.util.Scanner; public static void main(String [] args) { Scanner sc = new Scanner(Sys...
  • 這個是用Mac下的Network Utility工具實現ping命令,用Wireshark抓取的ICMP數據包:發送ICMP數據包內容接受ICMP數據包內容一.icmp結構要真正瞭解ping命令實現原理,就要瞭解ping命令所使用到的TCP/IP協議。ICMP(Internet Control Me...
  • 編譯打包 Spark支持Maven與SBT兩種編譯工具,這裡使用了Maven進行編譯打包; 在執行make distribution腳本時它會檢查本地是否已經存在Maven還有當前Spark所依賴的Scala版本,如果不存在它會自動幫你下載到build目錄中並解壓使用;Maven源最好...
  • 接《基於Cocos2d-x-1.0.1的飛機大戰游戲開發實例(上)》三、代碼分析1.界面初始化 1 bool PlaneWarGame::init() 2 { 3 bool bRet = false; 4 do 5 { 6 CC_BREAK_IF(! CCL...
  • 枚舉不要這麼做:全選複製放進筆記i = 0 for item in iterable: print i, item i += 1而是這樣:全選複製放進筆記for i, item in enumerate(iterable): print i, itemEnumerate可以接受...
  • 最近接觸過幾個版本的cocos2dx,決定每個大變動的版本都嘗試一下。本實例模仿微信5.0版本中的飛機大戰游戲,如圖:一、工具1.素材:飛機大戰的素材(圖片、聲音等)來自於網路2.引擎:cocos2d-1.0.1-x-0.9.23.環境:vs2010二、使用的類1.游戲菜單界面類:PlaneWarM...
  • 本文翻譯自modern effective C++,由於水平有限,故無法保證翻譯完全正確,歡迎指出錯誤。謝謝!矛盾的是,我們很容易就能創造出一個和std::shared_ptr類似的智能指針,但是,它們不參加被指向資源的共用所有權管理。換句話說,這是一個行為像std::shared_ptr,但卻不....
  • 轉載自:http://www.infoq.com/cn/articles/rethinking-mvc-mvvm 原文作者:唐巧被誤解的 MVCMVC 的歷史MVC,全稱是 Model View Controller,是模...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...