首頁 >web前端 >js教程 >js判斷行動端是否安裝某款app的多種方法_javascript技巧

js判斷行動端是否安裝某款app的多種方法_javascript技巧

WBOY
WBOY原創
2016-05-16 15:25:021367瀏覽

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

第一種方法:

一:判斷是那種設備

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

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

android();

if(isAndroid){
      function android(){
        window.location.href = "openwjtr://com.tyrbl.wjtr"; /***打开app的协议,有安卓同事提供***/
        window.setTimeout(function(){
           window.location.href = "http://www.wjtr.com/download/index.html"; /***打开app的协议,有安卓同事提供***/
        },2000);
      };

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

if(isiOS){
      function ios(){
        var ifr = document.createElement("iframe");
        ifr.src = "openwjtr://com.tyrbl.wjtr"; /***打开app的协议,有ios同事提供***/
        ifr.style.display = "none"; 
        document.body.appendChild(ifr);
        window.setTimeout(function(){
          document.body.removeChild(ifr);
           window.location.href = "http://www.wjtr.com/download/index.html"; /***下载app的地址***/
        },2000)
      };
}

第二種方法:

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

第三種方法:

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

<script language="javascript">
 if (navigator.userAgent.match(/(iPhone|iPod|iPad);&#63;/i)) {
  var loadDateTime = new Date();
  window.setTimeout(function() {
   var timeOutDateTime = new Date();
   if (timeOutDateTime - loadDateTime < 5000) {
    window.location = "要跳转的页面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 = "要跳转的页面URL";
  }
 }
</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的多種方法,希望對大家的學習有所幫助。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn