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

來源:互聯網
上載者:User

標籤:方法   index   rem   時間   test   space   ipa   keyword   datetime   

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

第一種方法:

一:判斷是那種裝置

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

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

第一種方法:

一:判斷是那種裝置

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

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

?
123456789 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();

?
123456789101112 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代碼:

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

js代碼:

?
1234567891011121314151617181920212223 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協議轉為本地軟體協議。 
還是直接貼代碼吧。
 如下: 

?
12345678910111213141516171819202122232425 <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 = "要跳轉的頁面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的多種方法,希望對大家的學習有所協助。

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.