js判斷移動端是否安裝某款app的多種方法


本文實例講解了js判斷移動端是否安裝某款app的多種方法,分享給大家供大家參考,具體內容如下

第一種方法:

一:判斷是那種設備

  1. var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1; //android終端或者uc瀏覽器  
  2. var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios終端  

二:安卓設備:原理:判斷是否認識這個協議,認識則直接跳轉,不認識就在這里下載app

  1. android();  
  2.   
  3. if(isAndroid){  
  4.       function android(){  
  5.         window.location.href = "openwjtr://com.tyrbl.wjtr"; /***打開app的協議,有安卓同事提供***/  
  6.         window.setTimeout(function(){  
  7.            window.location.href = "http://www.wjtr.com/download/index.html"; /***打開app的協議,有安卓同事提供***/  
  8.         },2000);  
  9.       };  

二:iOS設備:原理:判斷是否認識這個協議,認識則直接跳轉,不認識就在這里下載appios();

  1. if(isiOS){  
  2.       function ios(){  
  3.         var ifr = document.createElement("iframe");  
  4.         ifr.src = "openwjtr://com.tyrbl.wjtr"; /***打開app的協議,有ios同事提供***/  
  5.         ifr.style.display = "none";   
  6.         document.body.appendChild(ifr);  
  7.         window.setTimeout(function(){  
  8.           document.body.removeChild(ifr);  
  9.            window.location.href = "http://www.wjtr.com/download/index.html"; /***下載app的地址***/  
  10.         },2000)  
  11.       };  
  12. }  

第二種方法:

雖然在Js中可以啟動某個app,但是並不能判斷該app是否安裝;
啟動app需要的時間較長,js中斷時間長,如果沒安裝,js瞬間就執行完畢。直接上代碼吧!
html代碼:

  1. <href="javascript:testApp('tel:1868888888')">打電話</a>   

js代碼:

  1. function testApp(url) {   
  2.   var timeout, t = 1000, hasApp = true;   
  3.   setTimeout(function () {   
  4.     if (hasApp) {   
  5.       alert('安裝了app');   
  6.     } else {   
  7.       alert('未安裝app');   
  8.     }   
  9.     document.body.removeChild(ifr);   
  10.   }, 2000)   
  11.    
  12.   var t1 = Date.now();   
  13.   var ifr = document.createElement("iframe");   
  14.   ifr.setAttribute('src', url);   
  15.   ifr.setAttribute('style', 'display:none');   
  16.   document.body.appendChild(ifr);   
  17.   timeout = setTimeout(function () {   
  18.      var t2 = Date.now();   
  19.      if (!t1 || t2 - t1 < t + 100) {   
  20.        hasApp = false;   
  21.      }   
  22.   }, t);   
  23. }   

第三種方法:

最近在做項目的wap版,有個需求就是,先判斷手機上是否有我們的APP應用,如果有的話打開應用,沒有才跳轉到wap頁面。 
wap簡單來說就是運行在移動端瀏覽器上的網站。不管應用在什么地方,總之就是瀏覽器唄,可以通過JS來判斷本地是否有某應用,實現方式實際就是將http協議轉為本地軟件協議。 
還是直接貼代碼吧。
 如下: 

  1. <script language="javascript">  
  2.  if (navigator.userAgent.match(/(iPhone|iPod|iPad);?/i)) {  
  3.   var loadDateTime = new Date();  
  4.   window.setTimeout(function() {  
  5.    var timeOutDateTime = new Date();  
  6.    if (timeOutDateTime - loadDateTime < 5000) {  
  7.     window.location = "要跳轉的頁面URL";  
  8.    } else {  
  9.     window.close();  
  10.    }  
  11.   },  
  12.   25);  
  13.   window.location = " apps custom url schemes ";  
  14.  } else if (navigator.userAgent.match(/android/i)) {  
  15.   var state = null;  
  16.   try {  
  17.    state = window.open("apps custom url schemes ", '_blank');  
  18.   } catch(e) {}  
  19.   if (state) {  
  20.    window.close();  
  21.   } else {  
  22.    window.location = "要跳轉的頁面URL";  
  23.   }  
  24.  }  
  25. </script>  

apps custom url schemes 是什么呢?
其實就是你與APP約定的一個協議URL,你的ios同事或Android同事在寫程序的時候會設置一個URL Scheme,
例如設置:
URL Scheme :app
然后其他的程序就可以通過URLString = app://  調用該應用。
還可以傳參數,如:
app://reaction/?uid=1
原理:500ms內,本機有應用程序能解析這個協議並打開程序,調用該應用;如果本機沒有應用程序能解析該協議或者500ms內沒有打開這個程序,則執行setTimeout里面的function,就是跳轉到你想跳轉的頁面。

以上就是js判斷移動端是否安裝某款app的多種方法,希望對大家的學習有所幫助。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM