js 判斷微信瀏覽器(轉)

最近作不少HTML5的項目,不少頁面會經過微信微博等SNS分享出去。在分享頁面上提供公司APP的下載。可是在不少應用的瀏覽器中,點擊下載連接沒法下載應用。那麼針對這些瀏覽器咱們須要給用戶提示從safari或者系統自帶的瀏覽器打開分享頁面。經過js就能夠判斷當前頁面是在什麼瀏覽器打開的。javascript

如下是一段示例代碼,註釋中代表了經過JS如何判斷是否在微信瀏覽器打開,是否在QQ空間瀏覽器,是否在新浪微博打開。固然能夠作得更完善一點,再加上判斷是在移動設備打開仍是在PC端瀏覽器打開的,更加細分一點,能夠判斷是在安卓系統的瀏覽器打開的仍是IOS系統瀏覽器打開的。html

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瀏覽器,蘋果瀏覽器,谷歌瀏覽器,火狐瀏覽器等。java

 

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()
}

 


 

上週接到個需求,需求是這樣的:用戶掃一掃二維碼會產生一個連接,該連接會向後端發送個請求,返回一個 apk 的下載地址,用戶點擊下載按鈕能夠下載此 apk。而後就發生了問題,通過測試,發現用微信掃一掃打開的頁面點擊下載按鈕下載不了 apk,後百度之,原來是微信內置瀏覽器屏蔽了下載連接,後面和需求方溝通,需求改成若是用戶是用微信內置瀏覽器打開的,則提示用戶換一個瀏覽器打開頁面,不然下載不了 apk。那麼該如何判斷用戶是不是用微信瀏覽器呢?android

咱們知道 js 能夠經過 window.navigator.userAgent 來獲取瀏覽器的相關信息,好比:Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/33.0.1750.154 Safari/537.36,那麼咱們也能夠經過該方法來獲取微信內置瀏覽器的相關信息:Mozilla/5.0 (iPhone; CPU iPhone OS 7_1_1 like Mac OS X) AppleWebKit/537.51.2 (KHTML, like Gecko) Mobile/11d201 MicroMessenger/5.3。根據關鍵字 MicroMessenger 來判斷是不是微信內置的瀏覽器。判斷函數以下:ios

function isWeiXin(){
    var ua = window.navigator.userAgent.toLowerCase();
    if(ua.match(/MicroMessenger/i) == 'micromessenger'){
        return true;
    }else{
        return false;
    }
}

demo:web

<!DOCTYPE HTML>
<html lang="en">
<head>
    <meta charset="utf-8"/>
    <title>判斷是不是微信內置瀏覽器</title>
</head>
<body>
    <h1>若是用微信瀏覽器打開能夠看到下面的文字</h1>
    <p></p>
</body>
</html>
<script type="text/javascript">
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;
    }
}
</script>
相關文章
相關標籤/搜索