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

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

1.第一種方法:

一:判斷是那種設(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)識這個協(xié)議,認(rèn)識則直接跳轉(zhuǎn),不認(rèn)識就在這里下載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)識這個協(xié)議,認(rèn)識則直接跳轉(zhuǎn),不認(rèn)識就在這里下載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中可以啟動某個app,但是并不能判斷該app是否安裝;
啟動app需要的時間較長,js中斷時間長,如果沒安裝,js瞬間就執(zhí)行完畢。直接上代碼吧!


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);
}

第三種方法:

<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)的頁面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)的頁面URL";
  }
 }
</script>

四、注意事項(xiàng):

  1. apps custom url schemes 是什么呢?
其實(shí)就是你與APP約定的一個協(xié)議URL,你的IOS同事或Android同事在寫程序的時候會設(shè)置一個URL Scheme,
例如設(shè)置:
URL Scheme :app
然后其他的程序就可以通過URLString = app://  調(diào)用該應(yīng)用。
還可以傳參數(shù),如:
app://reaction/?uid=1

原理:500ms內(nèi),本機(jī)有應(yīng)用程序能解析這個協(xié)議并打開程序,調(diào)用該應(yīng)用;如果本機(jī)沒有應(yīng)用程序能解析該協(xié)議或者500ms內(nèi)沒有打開這個程序,則執(zhí)行setTimeout里面的function,就是跳轉(zhuǎn)到你想跳轉(zhuǎn)的頁面。
以上就是js判斷移動端是否安裝某款app的多種方法,希望對大家的學(xué)習(xí)有所幫助。

2. 網(wǎng)頁推薦下載App,如其本地已安裝則直接打開本地App

1.網(wǎng)頁推薦下載App,如果本地已安裝則直接打開本地App

function open_or_download_app() {
    if (navigator.userAgent.match(/(iPhone|iPod|iPad);?/i)) {
        // 判斷useragent,當(dāng)前設(shè)備為ios設(shè)備
        var loadDateTime = new Date(); // 設(shè)置時間閾值,在規(guī)定時間里面沒有打開對應(yīng)App的話,直接去App store進(jìn)行下載。
        window.setTimeout(function() {
            var timeOutDateTime = new Date();
            if (timeOutDateTime - loadDateTime < 2000) {
                window.location = "https://itunes.apple.com/cn/app/hu-lu/id627370076?mt=8";
            } else {
                window.close();
            }
        },  50);
        window.location = "XXX://"; // iOS端URL Schema
    } else if (navigator.userAgent.match(/android/i)) {
        // 判斷useragent,當(dāng)前設(shè)備為android設(shè)備
        window.location = "XXX://"; // Android端URL Schema
    }
}
10B9409F-57E5-4505-81A8-B207754F494C.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容