国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

判斷iOS、Android以及PC端的示例代碼

2024-05-06 15:27:56
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

我們?cè)谧鲆苿?dòng)端時(shí),在跨平臺(tái)、瀏覽器、移動(dòng)設(shè)備兼容的時(shí)候,要根據(jù)設(shè)備、瀏覽器做特定調(diào)整,想起用navigator.userAgent來(lái)對(duì)瀏覽器類型進(jìn)行判斷,查了點(diǎn)資料,在這里總結(jié)下

還有一個(gè)就是移動(dòng)端的縮放問(wèn)題,在meta標(biāo)簽中進(jìn)行設(shè)置,對(duì)部分瀏覽器進(jìn)行強(qiáng)制性的限制

1.navigator的一些常用屬性

navigator為window對(duì)象的一個(gè)屬性,指向了一個(gè)包含瀏覽器相關(guān)信息的對(duì)象

navigator.appVersion 瀏覽器的版本號(hào)
navigator.language 瀏覽器使用的語(yǔ)言
navigator.userAgent 瀏覽器的userAgent信息

其中userAgent 屬性是一個(gè)只讀的字符串,聲明了瀏覽器用于 HTTP 請(qǐng)求的用戶代理頭的值。

2.較常見(jiàn)的ios端、Android端及PC端的判斷

簡(jiǎn)單點(diǎn)的

/* 判斷瀏覽器類型 */let userAgent = navigator.userAgent;/* 判斷手機(jī)型號(hào) */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,   /* 判斷是否是移動(dòng)端 */   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手機(jī)或者QQHD瀏覽器 */   iphone: userAgent.indexOf('iPhone') > -1,   /* 判斷是否是iPad */   iPad: userAgent.indexOf('iPad') > -1,   /* 判斷是否是web應(yīng)用程序(能夠讓用戶完成某些特定任務(wù)的網(wǎng)站),沒(méi)有頭部和底部 */   webApp: userAgent.indexOf('Safari'),   /* 是否是微信 */   weixin: userAgent.indexOf('MicroMessenger'),   /* QQ */   QQ: userAgent.match(//sQQ/i) == ' qq',  } }(), /* 判斷瀏覽器使用的語(yǔ)言:navigator.language除IE瀏覽器外的瀏覽器使用的語(yǔ)言,  * navigator.browserLanguageIE瀏覽器使用的語(yǔ)言  */ browserLanguage: (navigator.language || navigator.browserLanguage).toLowerCase()};if(browser.version.ios || browser.version.android || browser.version.mobilePhone) { console.log('是移動(dòng)端');}

3.meta標(biāo)簽設(shè)置

如對(duì)瀏覽器進(jìn)行強(qiáng)制全屏的設(shè)置(UC全屏),webapp模式等

<meta charset="UTF-8"><!-- 視圖窗口,移動(dòng)端特屬的標(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強(qiáng)制豎屏 --><meta name="screen-orientation" content="portrait"><!-- QQ強(qiáng)制豎屏 --><meta name="x5-orientation" content="portrait"><!-- UC強(qiáng)制全屏 --><meta name="full-screen" content="yes"><!-- QQ強(qiáng)制全屏 --><meta name="x5-fullscreen" content="true"><!-- UC應(yīng)用模式 --><meta name="browsermode" content="application"><!-- QQ應(yīng)用模式 --><meta name="x5-page-mode" content="app"><!-- 是否啟動(dòng)webapp功能,會(huì)刪除默認(rèn)的蘋果工具欄和菜單欄 --><meta name="apple-mobile-web-app-capable" content="yes"><!-- 這個(gè)主要是根據(jù)實(shí)際的頁(yè)面設(shè)計(jì)的主體色為搭配來(lái)進(jìn)行設(shè)置 --><meta name="apple-mobile-web-app-status-bar-style" content="black"><!-- 忽略頁(yè)面中的數(shù)字識(shí)別為電話號(hào)碼,email識(shí)別 --><meta name="format-decoration" content="telephone=no,email=no"><!-- 啟用360瀏覽器的極速模式(webkit) --><meta name="renderer" content="webkit"><!-- 針對(duì)手持設(shè)備優(yōu)化,主要是針對(duì)一些老的不識(shí)別viewport的瀏覽器,比如黑莓 --><meta name="HandheldFriendly" content="true"><!-- 微軟的老式瀏覽器 --><meta name="MobileOptimized" content="320"><!-- windows phone 點(diǎn)擊無(wú)高光 --><meta name="msapplication-tap-highlight" content="no">            
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 左权县| 资兴市| 闽清县| 芒康县| 金塔县| 南城县| 北安市| 恩施市| 东辽县| 当阳市| 南岸区| 丰原市| 鹤壁市| 高青县| 南靖县| 西乌珠穆沁旗| 元朗区| 三原县| 凯里市| 云梦县| 清涧县| 香港 | 乌拉特中旗| 体育| 广东省| 沙河市| 孝昌县| 遂溪县| 林周县| 旺苍县| 精河县| 曲周县| 东宁县| 南丰县| 襄垣县| 延川县| 广灵县| 五大连池市| 淮安市| 民县| 应城市|