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

首頁 > 開發 > JS > 正文

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

2024-05-06 16:46:50
字體:
來源:轉載
供稿:網友

前言

我們在做移動端時,在跨平臺、瀏覽器、移動設備兼容的時候,要根據設備、瀏覽器做特定調整,想起用navigator.userAgent來對瀏覽器類型進行判斷,查了點資料,在這里總結下

還有一個就是移動端的縮放問題,在meta標簽中進行設置,對部分瀏覽器進行強制性的限制

1.navigator的一些常用屬性

navigator為window對象的一個屬性,指向了一個包含瀏覽器相關信息的對象

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內核 */   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('是移動端');}

3.meta標簽設置

如對瀏覽器進行強制全屏的設置(UC全屏),webapp模式等

<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">

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 梁平县| 平凉市| 儋州市| 定结县| 曲沃县| 象山县| 永兴县| 吴堡县| 定兴县| 繁昌县| 张家港市| 水富县| 望谟县| 库车县| 泗阳县| 德令哈市| 奎屯市| 永宁县| 井冈山市| 芮城县| 邵阳市| 枣强县| 建阳市| 镇坪县| 安泽县| 调兵山市| 永福县| 江北区| 石首市| 太仓市| 洮南市| 土默特右旗| 高要市| 舒城县| 宁国市| 海口市| 和田县| 和田县| 辽中县| 方正县| 辽中县|