判斷在移動端還是PC開啟

林Clown發表於2019-01-02

var browser = {
  versions: function() {
    var u = navigator.userAgent,
      app = navigator.appVersion;
    return { //移動終端瀏覽器版本資訊
      trident: u.indexOf('Trident') > -1, //IE核心
      presto: u.indexOf('Presto') > -1, //opera核心
      webKit: u.indexOf('AppleWebKit') > -1, //蘋果、谷歌核心
      gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐核心
      mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否為移動終端
      ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios終端
      android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android終端或uc瀏覽器
      iPhone: u.indexOf('iPhone') > -1, //是否為iPhone或者QQHD瀏覽器
      iPad: u.indexOf('iPad') > -1, //是否iPad
      webApp: u.indexOf('Safari') == -1 //是否web應該程式,沒有頭部與底部
    };
  }(),
  language: (navigator.browserLanguage || navigator.language).toLowerCase()
}
console.log(browser)

if (browser.versions.mobile) { //判斷是否是移動裝置開啟。browser程式碼在下面
  var ua = navigator.userAgent.toLowerCase(); //獲取判斷用的物件
  if (ua.match(/MicroMessenger/i) == "micromessenger") {
    //在微信中開啟
    console.error('11111')
    var appid = 'wx206f7c16f5d4531e'
    var locationUrl = window.location.href;
    var params = Qs.parse(window.location.search.substring(1))
    var weChatCode = params.code
    // alert('openid:' + localStorage.getItem('openid'))
    // alert('weChatCode:' + weChatCode)

    if(localStorage.getItem('openid') == null || localStorage.getItem('openid') === 'error'){

      //如果沒有設定openid
      if (weChatCode == null || weChatCode === '') {

        //如果沒有weChatCode,重定向獲取
        window.location.href = 'https://open.weixin.qq.com/connect/oauth2/authorize?appid=' + appid + '&redirect_uri=' +
        encodeURIComponent(locationUrl) + '&response_type=code&scope=snsapi_userinfo&state=1#wechat_redirect'
      } else {
        if (weChatCode != localStorage.getItem('weChatCode')) {
          localStorage.setItem('weChatCode', weChatCode)
          api.getOpenId({
            code: weChatCode
          }, function(res) {
            // alert(res)
            localStorage.setItem('openid', res.result)
          })
        }
      }
    }
  }
  if (ua.match(/WeiBo/i) == "weibo") {
    //在新浪微部落格戶端開啟
    // alert('在微博中開啟')
  }
  if (ua.match(/QQ/i) == "qq") {
    //在QQ空間開啟
    // alert('在qq空間中開啟')
  }
  if (browser.versions.ios) {
    //是否在IOS瀏覽器開啟
    // alert('在IOS瀏覽器中開啟')
  }
  if (browser.versions.android) {
    //是否在安卓瀏覽器開啟
    // alert('在安卓瀏覽器中開啟')
  }
} else {
  //否則就是PC瀏覽器開啟
  // alert('在PC瀏覽器中開啟')
}

相關文章