H5唤醒APP1

Posted on 2017-07-31 17:13  powerixao  阅读(166)  评论(0)    收藏  举报
  1. /启动app方法  
  2. function startApp(url, url2) {  
 
[javascript] view plain copy
 
  1. <span style="white-space:pre">          </span>//url是跳转的scheme地址,这个建议下个反编译的软件,去第三方apk查他们设置的scheme_url和scheme_host是什么,我就是这样干的  
[javascript] view plain copy
 
  1. <span style="white-space:pre">          </span>//url2是应用下载地址,要分清ios和android的不一样  
  2.             //将下载地址保存到全局变量  
  3.             downloadUrl = url2;  
  4.             if(ua.match(/ipad|iphone|ipod|ios/i)) {  
  5.                 //外部一个定时器,专门盯着启动app的定时器loop;就叫它killer吧  
  6.                 //计时6秒,之后干掉loop.  
  7.                 window.setTimeout(function() {  
  8.                     $('#message').html('');  
  9.                     $('.result-message').eq(0).css("display", "none");  
  10.                     clearTimeout(loop);  
  11.                     time = parseInt('6000') / 1000;  
  12.                 }, 6000);  
  13.                 //尝试启动应用  
  14.                 location.href = url;  
  15.                 //同时开始应用启动倒计时  
  16.                 countDown();  
  17.                   
  18.             } else {  
  19.                 //安卓的就是用iframe来测试是否安装和启动应用了  
  20.                 window.setTimeout(function() {  
  21.                     $('#message').html('');  
  22.                     $('.result-message').eq(0).css("display", "none");  
  23.                     clearTimeout(loop);  
  24.                     time = parseInt('6000') / 1000;  
  25.                 }, 6000);  
  26.                 //创建iframe并启动应用入口  
  27.                 openApp(url);  
  28.   
  29.             }  
  30.   
  31.         }  
  32.   
  33.         function openApp(src) {  
  34.             // 通过iframe的方式试图打开APP,如果能正常打开,会直接切换到APP  
  35.             var ifr = document.createElement('iframe');  
  36.             ifr.src = src;  
  37.             ifr.style.display = 'none';  
  38.             document.body.appendChild(ifr);  
  39.             //切换到iframe时  
  40.             //此时,会有个问题,如后切换到应用时间小于killer所需要杀死loop的时间,loop就会跳到下载提示,killer`就失去作用了  
  41.             countDown();  
  42.             window.setTimeout(function() {  
  43.                 document.body.removeChild(ifr);  
  44.             }, 5000);  
  45.             //倒计时  
  46.   
  47.         }  
  48.   
  49.         function countDown() {  
  50.             //每秒调用一次  
  51.             loop = window.setTimeout('countDown()', 1000);  
  52.             if(time > 0) {  
  53.                 $('.result-message').eq(0).css("display", "block");  
  54.                 $('#message').html('正在尝试打开客户端 ' + time + 's');  
  55.   
  56.                 time--;  
  57.                 if(time == 0) {  
  58.                     /*if(ua.match(/ipad|iphone|ipod|ios/i)){ 
  59.                         console.log(downloadUrl); 
  60.                         location.href = downloadUrl; 
  61.                     }*/  
  62.                     //如果计时到0,loop任然没被干掉,就说明应用没有启动,此时,跳到下载提示界面  
  63.                     //定时器的局限性还是很大,不能响应式反应,所以只能做到这一步了  
  64.                     $('#message').html('');  
  65.                     $('.result-message').eq(0).css("display", "none");  
  66.                     clearTimeout(loop);  
  67.                     time = parseInt('6000') / 1000;  
  68.                     var btnArray = ['否', '是'];  
  69.                     mui.confirm('您没有安装该应用,是否下载安装包?', '应用下载', btnArray, function(e) {  
  70.                         if(e.index == 1) {  
  71.                             location.replace(downloadUrl);  
  72.                         } else {  
  73.                             return;  
  74.                         }  
  75.                     });  
  76.                 }  
  77.             }  
  78.         }  

博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3