判斷iOS、Android以及PC端的示例代碼
前言
我們在做移動端時,在跨平臺、瀏覽器、移動設(shè)備兼容的時候,要根據(jù)設(shè)備、瀏覽器做特定調(diào)整,想起用navigator.userAgent來對瀏覽器類型進(jìn)行判斷,查了點資料,在這里總結(jié)下
還有一個就是移動端的縮放問題,在meta標(biāo)簽中進(jìn)行設(shè)置,對部分瀏覽器進(jìn)行強制性的限制
1.navigator的一些常用屬性
navigator為window對象的一個屬性,指向了一個包含瀏覽器相關(guān)信息的對象
navigator.appVersion 瀏覽器的版本號
navigator.language 瀏覽器使用的語言
navigator.userAgent 瀏覽器的userAgent信息
其中userAgent 屬性是一個只讀的字符串,聲明了瀏覽器用于 HTTP 請求的用戶代理頭的值。
2.較常見的ios端、Android端及PC端的判斷
簡單點的
/* 判斷瀏覽器類型 */
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內(nèi)核 */
trident: userAgent.indexOf('Trident') > -1,
/* opera內(nèi)核 */
presto: userAgent.indexOf('Presto') > -1,
/* 蘋果、谷歌內(nèi)核 */
webkit: userAgent.indexOf('AppleWebKit') > -1,
/* 火狐內(nèi)核 */
gecko: userAgent.indexOf('Gecko') > -1 && userAgent.indexOf('KHTML') == -1,
/* 判斷是否是IPone手機或者QQHD瀏覽器 */
iphone: userAgent.indexOf('iPhone') > -1,
/* 判斷是否是iPad */
iPad: userAgent.indexOf('iPad') > -1,
/* 判斷是否是web應(yīng)用程序(能夠讓用戶完成某些特定任務(wù)的網(wǎng)站),沒有頭部和底部 */
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('是移動端');
}
3.meta標(biāo)簽設(shè)置
如對瀏覽器進(jìn)行強制全屏的設(shè)置(UC全屏),webapp模式等
<meta charset="UTF-8"> <!-- 視圖窗口,移動端特屬的標(biāo)簽 --> <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應(yīng)用模式 --> <meta name="browsermode" content="application"> <!-- QQ應(yīng)用模式 --> <meta name="x5-page-mode" content="app"> <!-- 是否啟動webapp功能,會刪除默認(rèn)的蘋果工具欄和菜單欄 --> <meta name="apple-mobile-web-app-capable" content="yes"> <!-- 這個主要是根據(jù)實際的頁面設(shè)計的主體色為搭配來進(jìn)行設(shè)置 --> <meta name="apple-mobile-web-app-status-bar-style" content="black"> <!-- 忽略頁面中的數(shù)字識別為電話號碼,email識別 --> <meta name="format-decoration" content="telephone=no,email=no"> <!-- 啟用360瀏覽器的極速模式(webkit) --> <meta name="renderer" content="webkit"> <!-- 針對手持設(shè)備優(yōu)化,主要是針對一些老的不識別viewport的瀏覽器,比如黑莓 --> <meta name="HandheldFriendly" content="true"> <!-- 微軟的老式瀏覽器 --> <meta name="MobileOptimized" content="320"> <!-- windows phone 點擊無高光 --> <meta name="msapplication-tap-highlight" content="no">
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
window.location的重寫及判斷l(xiāng)ocation是否被重寫
這篇文章主要介紹了window.location的重寫及判斷l(xiāng)ocation是否被重寫,需要的朋友可以參考下2014-09-09
Javascript打印網(wǎng)頁部分內(nèi)容的腳本
有時候我們只需要打印部分內(nèi)容,因為現(xiàn)在的頁面中廣告和一些相關(guān)內(nèi)容很多,所有用下面的方法,就可以了2008-11-11
JavaScript時間日期操作實例小結(jié)【5個示例】
這篇文章主要介紹了JavaScript時間日期操作,結(jié)合5個具體實例形式分析了javascript針對日期時間的各種常見操作技巧,需要的朋友可以參考下2018-12-12

