在作移動端時,想起用navigator.userAgent來對瀏覽器類型進行判斷,查了點資料,在這裏總結下
還有一個就是移動端的縮放問題,在meta標籤中進行設置,對部分瀏覽器進行強制性的限制
navigator.appVersion 瀏覽器的版本號 navigator.language 瀏覽器使用的語言 navigator.userAgent 瀏覽器的userAgent信息
其中userAgent 屬性是一個只讀的字符串,聲明瞭瀏覽器用於 HTTP 請求的用戶代理頭的值。
/* 判斷瀏覽器類型 */ let userAgent = navigator.userAgent; /* 判斷手機型號 */ let app = navigator.appVersion; /* Android 終端 */ let isAndroid = userAgent.indexOf('Android'); /* ios終端 */ let isMac = !!userAgent.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
/* 判斷各種型方法 */ const browser = { version: function() { const userAgent = navigator.userAgent; return { /* 判斷是不是ios */ ios: !!userAgent.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), /* 判斷是不是Android */ android: userAgent.indexOf('Android') > -1 || userAgent.indexOf('Adr') > -1, /* 判斷是不是移動端 */ mobilePhone: !!userAgent.match(/AppleWebKit.*Mobile.*/), /* IE內核 */ trident: userAgent.indexOf('Trident') > -1, /* opera內核 */ presto: userAgent.indexOf('Presto') > -1, /* 蘋果、谷歌內核 */ webkit: userAgent.indexOf('AppleWebKit') > -1, /* 火狐內核 */ gecko: userAgent.indexOf('Gecko') > -1 && userAgent.indexOf('KHTML') == -1, /* 判斷是不是IPone手機或者QQHD瀏覽器 */ iphone: userAgent.indexOf('iPhone') > -1, /* 判斷是不是iPad */ iPad: userAgent.indexOf('iPad') > -1, /* 判斷是不是web應用程序(可以讓用戶完成某些特定任務的網站),沒有頭部和底部 */ webApp: userAgent.indexOf('Safari'), /* 是不是微信 */ weixin: userAgent.indexOf('MicroMessenger'), /* QQ */ QQ: userAgent.match(/\sQQ/i) == ' qq', } }(), /* 判斷瀏覽器使用的語言:navigator.language除IE瀏覽器外的瀏覽器使用的語言, * navigator.browserLanguageIE瀏覽器使用的語言 */ browserLanguage: (navigator.language || navigator.browserLanguage).toLowerCase() }; if(browser.version.ios || browser.version.android || browser.version.mobilePhone) { console.log('是移動端'); }
<meta charset="UTF-8"> <!-- 視圖窗口,移動端特屬的標籤 --> <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no"> <!-- 避免IE使用兼容模式 --> <meta http-equiv="x-ua-compatible" content="IE=edge"> <!-- uc強制豎屏 --> <meta name="screen-orientation" content="portrait"> <!-- QQ強制豎屏 --> <meta name="x5-orientation" content="portrait"> <!-- UC強制全屏 --> <meta name="full-screen" content="yes"> <!-- QQ強制全屏 --> <meta name="x5-fullscreen" content="true"> <!-- UC應用模式 --> <meta name="browsermode" content="application"> <!-- QQ應用模式 --> <meta name="x5-page-mode" content="app"> <!-- 是否啓動webapp功能,會刪除默認的蘋果工具欄和菜單欄 --> <meta name="apple-mobile-web-app-capable" content="yes"> <!-- 這個主要是根據實際的頁面設計的主體色爲搭配來進行設置 --> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <!-- 忽略頁面中的數字識別爲電話號碼,email識別 --> <meta name="format-decoration" content="telephone=no,email=no"> <!-- 啓用360瀏覽器的極速模式(webkit) --> <meta name="renderer" content="webkit"> <!-- 針對手持設備優化,主要是針對一些老的不識別viewport的瀏覽器,好比黑莓 --> <meta name="HandheldFriendly" content="true"> <!-- 微軟的老式瀏覽器 --> <meta name="MobileOptimized" content="320"> <!-- windows phone 點擊無高光 --> <meta name="msapplication-tap-highlight" content="no">
正在努力學習中,若對你的學習有幫助,留下你的印記唄(點個贊咯^_^)
往期好文推薦:css