js判斷移動(dòng)端是否安裝某款app的多種方法
本文實(shí)例講解了js判斷移動(dòng)端是否安裝某款app的多種方法,分享給大家供大家參考,具體內(nèi)容如下
第一種方法:
一:判斷是那種設(shè)備
var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1; //android終端或者uc瀏覽器
var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios終端
二:安卓設(shè)備:原理:判斷是否認(rèn)識(shí)這個(gè)協(xié)議,認(rèn)識(shí)則直接跳轉(zhuǎn),不認(rèn)識(shí)就在這里下載app
android();
if(isAndroid){
function android(){
window.location.href = "openwjtr://com.tyrbl.wjtr"; /***打開app的協(xié)議,有安卓同事提供***/
window.setTimeout(function(){
window.location.; /***打開app的協(xié)議,有安卓同事提供***/
},2000);
};
二:ios設(shè)備:原理:判斷是否認(rèn)識(shí)這個(gè)協(xié)議,認(rèn)識(shí)則直接跳轉(zhuǎn),不認(rèn)識(shí)就在這里下載appios();
if(isiOS){
function ios(){
var ifr = document.createElement("iframe");
ifr.src = "openwjtr://com.tyrbl.wjtr"; /***打開app的協(xié)議,有ios同事提供***/
ifr.style.display = "none";
document.body.appendChild(ifr);
window.setTimeout(function(){
document.body.removeChild(ifr);
window.location.; /***下載app的地址***/
},2000)
};
}
第二種方法:
雖然在Js中可以啟動(dòng)某個(gè)app,但是并不能判斷該app是否安裝;
啟動(dòng)app需要的時(shí)間較長(zhǎng),js中斷時(shí)間長(zhǎng),如果沒安裝,js瞬間就執(zhí)行完畢。直接上代碼吧!
html代碼:
<a href="javascript:testApp('tel:1868888888')">打電話</a>
js代碼:
function testApp(url) {
var timeout, t = 1000, hasApp = true;
setTimeout(function () {
if (hasApp) {
alert('安裝了app');
} else {
alert('未安裝app');
}
document.body.removeChild(ifr);
}, 2000)
var t1 = Date.now();
var ifr = document.createElement("iframe");
ifr.setAttribute('src', url);
ifr.setAttribute('style', 'display:none');
document.body.appendChild(ifr);
timeout = setTimeout(function () {
var t2 = Date.now();
if (!t1 || t2 - t1 < t + 100) {
hasApp = false;
}
}, t);
}
第三種方法:
最近在做項(xiàng)目的wap版,有個(gè)需求就是,先判斷手機(jī)上是否有我們的APP應(yīng)用,如果有的話打開應(yīng)用,沒有才跳轉(zhuǎn)到wap頁(yè)面。
wap簡(jiǎn)單來說就是運(yùn)行在移動(dòng)端瀏覽器上的網(wǎng)站。不管應(yīng)用在什么地方,總之就是瀏覽器唄,可以通過JS來判斷本地是否有某應(yīng)用,實(shí)現(xiàn)方式實(shí)際就是將http協(xié)議轉(zhuǎn)為本地軟件協(xié)議。
還是直接貼代碼吧。
如下:
<script language="javascript">
if (navigator.userAgent.match(/(iPhone|iPod|iPad);?/i)) {
var loadDateTime = new Date();
window.setTimeout(function() {
var timeOutDateTime = new Date();
if (timeOutDateTime - loadDateTime < 5000) {
window.location = "要跳轉(zhuǎn)的頁(yè)面URL";
} else {
window.close();
}
},
25);
window.location = " apps custom url schemes ";
} else if (navigator.userAgent.match(/android/i)) {
var state = null;
try {
state = window.open("apps custom url schemes ", '_blank');
} catch(e) {}
if (state) {
window.close();
} else {
window.location = "要跳轉(zhuǎn)的頁(yè)面URL";
}
}
</script>
apps custom url schemes 是什么呢?
其實(shí)就是你與APP約定的一個(gè)協(xié)議URL,你的IOS同事或Android同事在寫程序的時(shí)候會(huì)設(shè)置一個(gè)URL Scheme,
例如設(shè)置:
URL Scheme :app
然后其他的程序就可以通過URLString = app:// 調(diào)用該應(yīng)用。
還可以傳參數(shù),如:
app://reaction/?uid=1
原理:500ms內(nèi),本機(jī)有應(yīng)用程序能解析這個(gè)協(xié)議并打開程序,調(diào)用該應(yīng)用;如果本機(jī)沒有應(yīng)用程序能解析該協(xié)議或者500ms內(nèi)沒有打開這個(gè)程序,則執(zhí)行setTimeout里面的function,就是跳轉(zhuǎn)到你想跳轉(zhuǎn)的頁(yè)面。
以上就是js判斷移動(dòng)端是否安裝某款app的多種方法,希望對(duì)大家的學(xué)習(xí)有所幫助。
- 利用js判斷手機(jī)是否安裝某個(gè)app的多種方案
- JSP中實(shí)現(xiàn)判斷客戶端手機(jī)類型并跳轉(zhuǎn)到app下載頁(yè)面
- 用于deeplink的js方法(判斷手機(jī)是否安裝app)
- JS監(jiān)聽微信、支付寶等移動(dòng)app及瀏覽器的返回、后退、上一頁(yè)按鈕的事件方法
- JS實(shí)現(xiàn)點(diǎn)擊網(wǎng)頁(yè)判斷是否安裝app并打開否則跳轉(zhuǎn)app store
- js實(shí)現(xiàn)微信/QQ直接跳轉(zhuǎn)到支付寶APP打開口令領(lǐng)紅包功能
- JS觸摸屏網(wǎng)頁(yè)版仿app彈窗型滾動(dòng)列表選擇器/日期選擇器
- JS拉起或下載app的實(shí)現(xiàn)代碼
- js判斷手機(jī)是否安裝并打開app,未安裝則安裝app【兼容Android、ios,親測(cè)可用】
相關(guān)文章
JSON格式的時(shí)間/Date(2367828670431)/格式轉(zhuǎn)為正常的年-月-日 格式的代碼
這篇文章主要介紹了JSON格式的時(shí)間/Date(2367828670431)/格式轉(zhuǎn)為正常的年-月-日 格式的代碼的相關(guān)資料,需要的朋友可以參考下2016-07-07
JS實(shí)現(xiàn)鼠標(biāo)框選效果完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)鼠標(biāo)框選效果,可實(shí)現(xiàn)鼠標(biāo)點(diǎn)擊出現(xiàn)框選效果的功能,同時(shí)下方實(shí)時(shí)顯示框選大小,涉及javascript鼠標(biāo)事件的響應(yīng)與頁(yè)面元素的動(dòng)態(tài)運(yùn)算技巧,需要的朋友可以參考下2016-06-06
微信小程序頁(yè)面?zhèn)鞫鄠€(gè)參數(shù)跳轉(zhuǎn)頁(yè)面的實(shí)現(xiàn)方法
這篇文章主要介紹了微信小程序頁(yè)面?zhèn)鞫鄠€(gè)參數(shù)跳轉(zhuǎn)頁(yè)面的實(shí)現(xiàn)方法,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05
從jQuery.camelCase()學(xué)習(xí)string.replace() 函數(shù)學(xué)習(xí)
camelCase函數(shù)的功能就是將形如background-color轉(zhuǎn)化為駝峰表示法:backgroundColor。2011-09-09

