欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年11月15日 08:37:46   作者:ZJW0215  
這篇文章主要給大家介紹了關(guān)于如何判斷iOS、Android以及PC端的相關(guān)資料,主要是利用navigator.userAgent來實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

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

還有一個(gè)就是移動(dòng)端的縮放問題,在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 瀏覽器使用的語言
navigator.userAgent 瀏覽器的userAgent信息

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

2.較常見的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)站),沒有頭部和底部 */
   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('是移動(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í)際的頁面設(shè)計(jì)的主體色為搭配來進(jìn)行設(shè)置 -->
<meta name="apple-mobile-web-app-status-bar-style" content="black">
<!-- 忽略頁面中的數(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)擊無高光 -->
<meta name="msapplication-tap-highlight" content="no">

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • JavaScript的事件代理和委托實(shí)例分析

    JavaScript的事件代理和委托實(shí)例分析

    在javasript中delegate這個(gè)詞經(jīng)常出現(xiàn),看字面的意思,代理、委托。在各種框架中,也經(jīng)常能看到delegate相關(guān)的接口。這些接口又有什么特殊的用法呢?這篇文章就主要通過實(shí)例介紹一下javascript delegate的用法和原理。
    2015-03-03
  • window.location的重寫及判斷l(xiāng)ocation是否被重寫

    window.location的重寫及判斷l(xiāng)ocation是否被重寫

    這篇文章主要介紹了window.location的重寫及判斷l(xiāng)ocation是否被重寫,需要的朋友可以參考下
    2014-09-09
  • layui多iframe頁面控制定時(shí)器運(yùn)行的方法

    layui多iframe頁面控制定時(shí)器運(yùn)行的方法

    今天小編就為大家分享一篇layui多iframe頁面控制定時(shí)器運(yùn)行的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 五段實(shí)用的js高級(jí)技巧

    五段實(shí)用的js高級(jí)技巧

    五段實(shí)用的js高級(jí)技巧,一些不錯(cuò)的小技巧,學(xué)習(xí)js的朋友可以看看。
    2011-12-12
  • JavaScript前端優(yōu)化策略深入詳解

    JavaScript前端優(yōu)化策略深入詳解

    在前端開發(fā)中,優(yōu)化頁面性能是非常重要的一個(gè)方面,頁面性能優(yōu)化可以提升網(wǎng)站的用戶體驗(yàn),加速頁面的加載速度,提高用戶的滿意度,本文講解了前端通用的優(yōu)化策略,需要詳細(xì)了解可以參考下
    2023-05-05
  • js讀取配置文件自寫

    js讀取配置文件自寫

    這篇文章主要介紹了js讀取配置文件的方法,需要的朋友可以參考下
    2014-02-02
  • JavaScript導(dǎo)出Excel實(shí)例詳解

    JavaScript導(dǎo)出Excel實(shí)例詳解

    這篇文章主要介紹了JavaScript導(dǎo)出Excel的方法,以實(shí)例形式詳細(xì)分析了javascript將WEB頁面導(dǎo)出為EXCEL文檔的方法及相關(guān)的技巧說明,對(duì)于深入了解javascript編程原理有一定的借鑒價(jià)值,需要的朋友可以參考下
    2014-11-11
  • Javascript打印網(wǎng)頁部分內(nèi)容的腳本

    Javascript打印網(wǎng)頁部分內(nèi)容的腳本

    有時(shí)候我們只需要打印部分內(nèi)容,因?yàn)楝F(xiàn)在的頁面中廣告和一些相關(guān)內(nèi)容很多,所有用下面的方法,就可以了
    2008-11-11
  • 利用JS制作萬年歷的方法

    利用JS制作萬年歷的方法

    本篇文章主要介紹了利用JS制作萬年歷的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • JavaScript時(shí)間日期操作實(shí)例小結(jié)【5個(gè)示例】

    JavaScript時(shí)間日期操作實(shí)例小結(jié)【5個(gè)示例】

    這篇文章主要介紹了JavaScript時(shí)間日期操作,結(jié)合5個(gè)具體實(shí)例形式分析了javascript針對(duì)日期時(shí)間的各種常見操作技巧,需要的朋友可以參考下
    2018-12-12

最新評(píng)論