1. 程式人生 > >判斷ios和Android及PC端

判斷ios和Android及PC端

在做移動端時,想起用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">
正在努力學習中,若對你的學習有幫助,留下你的印記唄(點個贊咯^_^)