网站首页 > 基础教程 正文
啥话不说,先上js代码
- //启动app方法
- function startApp(url, url2) {
//url是跳转的scheme地址,这个建议下个反编译的软件,去第三方apk查他们设置的scheme_url和scheme_host是什么,我就是这样干的
- //url2是应用下载地址,要分清ios和android的不一样
- //将下载地址保存到全局变量
- downloadUrl = url2;
- if(ua.match(/ipad|iphone|ipod|ios/i)) {
- //外部一个定时器,专门盯着启动app的定时器loop;就叫它killer吧
- //计时6秒,之后干掉loop.
- window.setTimeout(function() {
- $('#message').html('');
- $('.result-message').eq(0).css("display", "none");
- clearTimeout(loop);
- time = parseInt('6000') / 1000;
- }, 6000);
- //尝试启动应用
- location.href = url;
- //同时开始应用启动倒计时
- countDown();
- } else {
- //安卓的就是用iframe来测试是否安装和启动应用了
- window.setTimeout(function() {
- $('#message').html('');
- $('.result-message').eq(0).css("display", "none");
- clearTimeout(loop);
- time = parseInt('6000') / 1000;
- }, 6000);
- //创建iframe并启动应用入口
- openApp(url);
- }
- }
- function openApp(src) {
- // 通过iframe的方式试图打开APP,如果能正常打开,会直接切换到APP
- var ifr = document.createElement('iframe');
- ifr.src = src;
- ifr.style.display = 'none';
- document.body.appendChild(ifr);
- //切换到iframe时
- //此时,会有个问题,如后切换到应用时间小于killer所需要杀死loop的时间,loop就会跳到下载提示,killer`就失去作用了
- countDown();
- window.setTimeout(function() {
- document.body.removeChild(ifr);
- }, 5000);
- //倒计时
- }
- function countDown() {
- //每秒调用一次
- loop = window.setTimeout('countDown()', 1000);
- if(time > 0) {
- $('.result-message').eq(0).css("display", "block");
- $('#message').html('正在尝试打开客户端 ' + time + 's');
- time--;
- if(time == 0) {
- /*if(ua.match(/ipad|iphone|ipod|ios/i)){
- console.log(downloadUrl);
- location.href = downloadUrl;
- }*/
- //如果计时到0,loop任然没被干掉,就说明应用没有启动,此时,跳到下载提示界面
- //定时器的局限性还是很大,不能响应式反应,所以只能做到这一步了
- $('#message').html('');
- $('.result-message').eq(0).css("display", "none");
- clearTimeout(loop);
- time = parseInt('6000') / 1000;
- var btnArray = ['否', '是'];
- mui.confirm('您没有安装该应用,是否下载安装包?', '应用下载', btnArray, function(e) {
- if(e.index == 1) {
- location.replace(downloadUrl);
- } else {
- return;
- }
- });
- }
- }
- }
整理了一下,定时器还是不好用,这也是没办法的办法了,网上大多的教程都是定时器,不是定时器的我又不明白人家啥意思,而且大部分都是安卓的,ios就是个坑,safari不支持iframe的跳转,就搞的我人都凌乱了,只能自己想办法,这个之前那个两个定时器控制的调转差不多,将就着看吧
猜你喜欢
- 2024-10-12 纯JS手写轮播图(代码逻辑清晰,通俗易懂)
- 2024-10-12 谷歌浏览器任意文件访问漏洞(CVE-2023-4357)复现
- 2024-10-12 Dom节点优化方案 dom节点树例题
- 2024-10-12 自动化测试工程师的学习方法和逻辑
- 2024-10-12 Web Components 系列(八)——自定义组件的样式设置
- 2024-10-12 JavaScript,自制弹窗(练习) js弹出自定义窗口
- 2024-10-12 掌握 onmouseover 事件:打造动态 HTML 体验
- 2024-10-12 Vue 自定义指令详解-按钮级权限示例(干货)
- 2024-10-12 windows本地程序调用与selenium的简单应用
- 2024-10-12 中高级渗透测试员都必须掌握的Web安全测试知识库,速收藏!
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)