JS簡(jiǎn)單判斷是否在微信瀏覽器打開的方法示例
本文實(shí)例講述了JS簡(jiǎn)單判斷是否在微信瀏覽器打開的方法。分享給大家供大家參考,具體如下:
最近做很多HTML5的項(xiàng)目,很多頁(yè)面會(huì)通過(guò)微信微博等SNS分享出去。在分享頁(yè)面上提供公司APP的下載。但是在很多應(yīng)用的瀏覽器中,點(diǎn)擊下載鏈接無(wú)法下載應(yīng)用。那么針對(duì)這些瀏覽器我們需要給用戶提示從safari或者系統(tǒng)自帶的瀏覽器打開分享頁(yè)面。通過(guò)js就可以判斷當(dāng)前頁(yè)面是在什么瀏覽器打開的。
<script>
var ua = navigator.userAgent.toLowerCase();
var isWeixin = ua.indexOf('micromessenger') != -1;
if (!isWeixin) {
window.location.
}
</script>
只要不是在微信內(nèi)部打開網(wǎng)頁(yè)的,就會(huì)跳轉(zhuǎn)提示頁(yè)面,appid必寫,可隨意寫,也可以寫已獲取的。
還是覺得跳轉(zhuǎn)比較好,防止別人查看自己的代碼。
以下是一段示例代碼,注釋中表明了通過(guò)JS如何判斷是否在微信瀏覽器打開,是否在QQ空間瀏覽器,是否在新浪微博打開。當(dāng)然可以做得更完善一點(diǎn),再加上判斷是在移動(dòng)設(shè)備打開還是在PC端瀏覽器打開的,更加細(xì)分一點(diǎn),可以判斷是在安卓系統(tǒng)的瀏覽器打開的還是IOS系統(tǒng)瀏覽器打開的。
if (browser.versions.mobile) {//判斷是否是移動(dòng)設(shè)備打開。browser代碼在下面
var ua = navigator.userAgent.toLowerCase();//獲取判斷用的對(duì)象
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的代碼,通過(guò)以下方法可以判斷很多瀏覽器。包括判斷IE瀏覽器,Opera瀏覽器,蘋果瀏覽器,谷歌瀏覽器,火狐瀏覽器等。
var browser = {
versions: function () {
var u = navigator.userAgent, app = navigator.appVersion;
return { //移動(dòng)終端瀏覽器版本信息
trident: u.indexOf('Trident') > -1, //IE內(nèi)核
presto: u.indexOf('Presto') > -1, //opera內(nèi)核
webKit: u.indexOf('AppleWebKit') > -1, //蘋果、谷歌內(nèi)核
gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐內(nèi)核
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否為移動(dòng)終端
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應(yīng)該程序,沒有頭部與底部
};
}(),
language: (navigator.browserLanguage || navigator.language).toLowerCase()
}
PS:這里再為大家提供幾款相關(guān)在線工具供大家參考:
在線瀏覽器信息檢測(cè)工具:
http://tools.jb51.net/aideddesign/browser_info
常用瀏覽器(PC,移動(dòng)) user-agent:
http://tools.jb51.net/table/useragent
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript操作DOM技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
教你JS更簡(jiǎn)單的獲取表單中數(shù)據(jù)(formdata)
這篇文章主要介紹了JS更簡(jiǎn)單的獲取表單中數(shù)據(jù)(formdata),本文給大家分享的js獲取表單數(shù)據(jù)更簡(jiǎn)潔,通過(guò)兩種方法結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05
簡(jiǎn)單的仿Flash文字動(dòng)畫(兼容Mozilla)
簡(jiǎn)單的仿Flash文字動(dòng)畫(兼容Mozilla)...2007-01-01
JavaScript極簡(jiǎn)入門教程(二):對(duì)象和函數(shù)
這篇文章主要介紹了JavaScript極簡(jiǎn)入門教程(二):對(duì)象和函數(shù),本文講解了對(duì)象基礎(chǔ)知識(shí)、函數(shù)基礎(chǔ)知識(shí)、函數(shù)調(diào)用、異常、繼承等內(nèi)容,需要的朋友可以參考下2014-10-10
Js如何判斷客戶端是PC還是手持設(shè)備簡(jiǎn)單分析
在工作過(guò)程中,許多朋友會(huì)經(jīng)常用到j(luò)s判斷客戶端是PC還是手持設(shè)備,今天將提供以下方法,需要的朋友可以參考下2012-11-11

