瀏覽器判斷

最近做很多HTML5的項目,很多頁面會通過微信微博等SNS分享出去。在分享頁面上提供公司APP的下載。但是在很多應用的瀏覽器中,點擊下載鏈接無法下載應用。那麼針對這些瀏覽器我們需要給用戶提示從safari或者系統自帶的瀏覽器打開分享頁面。通過js就可以判斷當前頁面是在什麼瀏覽器打開的。

以下是一段示例代碼,註釋中表明瞭通過JS如何判斷是否在微信瀏覽器打開,是否在QQ空間瀏覽器,是否在新浪微博打開。當然可以做得更完善一點,再加上判斷是在移動設備打開還是在PC端瀏覽器打開的,更加細分一點,可以判斷是在安卓系統的瀏覽器打開的還是IOS系統瀏覽器打開的。

if (browser.versions.mobile) {//判斷是否是移動設備打開。browser代碼在下面
var ua = navigator.userAgent.toLowerCase();//獲取判斷用的對象
if (ua.match(/MicroMessenger/i) == “micromessenger”) {
//在微信中打開
}
if (ua.match(/WeiBo/i) == “weibo”) {
//在新浪微博客戶端打開
}
if (ua.match(/QQ/i) == “qq”) {
//在QQ空間打開
}
if (browser.versions.ios) {
//是否在IOS瀏覽器打開
}
if(browser.versions.android){
//是否在安卓瀏覽器打開
}
} else {
//否則就是PC瀏覽器打開
}

再附上browser的代碼,通過以下方法可以判斷很多瀏覽器。包括判斷IE瀏覽器,Opera瀏覽器,蘋果瀏覽器,谷歌瀏覽器,火狐瀏覽器等。
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()
}

另一種方法:




判斷是否是微信內置瀏覽器


如果用微信瀏覽器打開可以看到下面的文字




window.onload = function(){ if(isWeiXin()){ var p = document.getElementsByTagName('p'); p[0].innerHTML = window.navigator.userAgent; } } function isWeiXin(){ var ua = window.navigator.userAgent.toLowerCase(); if(ua.match(/MicroMessenger/i) == 'micromessenger'){ return true; }else{ return false; } }
發佈了147 篇原創文章 · 獲贊 11 · 訪問量 45萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章