H5 唤起 APP的解决方案
H5 页面唤起APP或跳转到下载APP的某个链接地址。总结如下:
在 IOS 中, 系统版本在 8 以下时,可以监听页面的 pagehide / visibilitychange 事件。 系统版本大于 8 以后,可以使用 universal Link 或 URL scheme 进行跳转。
// IOS 的唤起function vForIOS(urlScheme, storeURL, fallback, universalLink) { var tid = deferFallback(TIMEOUT_IOS, storeURL, fallback); if (parseInt(os.version, 10) < 8) { bindPagehideEvent(tid); } else { bindVisibilityChangeEvent(tid); } if (parseInt(os.version, 10) > 8 && os.name == 'iOS') { // 通过universalLink if (universalLink === undefined) { universalLink = urlScheme; } else { clearTimeout(tid); } vLocation(universalLink); } else { vIframe(urlScheme); }} |
在安卓中, 安卓版本 4.4.4 以上机型的安卓自带浏览器、chrome 浏览器,需要通过 intent 跳转 【详情请见 https://developer.chrome.com/multidevice/android/intents】,其他浏览器大多数可通过 url scheme 唤起。但由于唤起APP后浏览器并无回调事件,我们很难判断是否已成功拉起APP,比较通用的解决办法是判断计时器是否变慢,若APP启动浏览器最小化入后台将会导致计时器变慢,即为实际事件间隔大于理想时间间隔。若未变慢则判断为未成功拉起APP,则跳转至下载地址。此判断代码如下:
function deferFallback(timeout, storeURL, fallback) { var clickedAt = new Date().getTime(); return setTimeout(function () { var now = new Date().getTime(); if (isPageVisible() && now - clickedAt < timeout + INTERVAL) { fallback(storeURL); } }, timeout); } |
安卓系统中,不同浏览器对唤起APP有严重的兼容性问题,主要处理方案有以下几种:
- 通过改变 window.location.href
- 通过创建 iframe 并为其 src 赋值
- 通过 intent
- 通过制造不可见 a 链接,并触发点击时间
// 打开页面的方式可能 // 1. 通过改变location function vLocation(urlScheme) { window.location.href = urlScheme; } // 2. 通过ifreame function vIframe(urlScheme) { setTimeout(function () { var iframe = createHiddenIframe('appLauncher'); iframe.src = urlScheme; }, 100); } // 3. 通过intent function vIntent(launchURI) { if (browser.name == 'Chrome') { move(); } else { setTimeout(move, 100); } function move() { // window.top.location.href = launchURI; window.location.href = launchURI } } // 3. 通过添加出发alink function vAlink(launchURI) { var aLink = document.createElement("a"); aLink.setAttribute("href", launchURI); aLink.style.display = "none"; document.body.appendChild(aLink); var event = document.createEvent("HTMLEvents"); event.initEvent("click", !1, !1); aLink.dispatchEvent(event) } // IOS 中的 可见性事件 function bindPagehideEvent(tid) { window.addEventListener('pagehide', function clear() { if (isPageVisible()) { clearTimeout(tid); window.removeEventListener('pagehide', clear); } }); } function bindVisibilityChangeEvent(tid) { document.addEventListener('visibilitychange', function clear() { if (isPageVisible()) { clearTimeout(tid); document.removeEventListener('visibilitychange', clear); } }); } function isPageVisible() { var attrNames = ['hidden', 'webkitHidden']; for (var i = 0, len = attrNames.length; i < len; i++) { if (typeof document[attrNames[i]] !== 'undefined') { return !document[attrNames[i]]; } } return true; } |
已知的浏览器兼容问题:
- 上述 chrome 和 Android Browser 可以使用 intent 的方式拉起 app
- QQ 浏览器 无法正确判断计时器是否变慢
- 微信浏览器 和 百度浏览器 无法唤起 app 除非加入其白名单
- 安卓4.4.4以前的 UC浏览器无法正确识别为 【安卓系统】需要单独设置判断条件
另: 研究京东唤起APP的代码时,其对百度浏览器做了如下操作,但我们对此的尝试并为成功,如下为其代码, 希望对后续研究此项的同学有帮助 :
function ai(aA) { var aD = ay(aA, true); var aB = aA.universalLinksUrl + "/ul/ul.action?" + aD; if (navigator.userAgent.indexOf("baidubrowser") >= 0) { window.location.href = aB } else { var az = document.createElement("a"); az.setAttribute("href", aB); az.style.display = "none"; document.body.appendChild(az); var aC = document.createEvent("HTMLEvents"); aC.initEvent("click", !1, !1); az.dispatchEvent(aC) }} |
H5 唤起 APP的解决方案的更多相关文章
- H5唤起app
H5唤起app 1.判断是否在微信中打开 无论是在哪个平台的客户端Android/IOS,在微信的平台上访问都有一个问题,那就是无法启动客户端,这是微信为了安全性考虑的限制,android这边屏蔽sc ...
- h5唤起APP并检查是否成功
// 检查app是否打开 function checkOpen(cb) { const clickTime = +(new Date()); function check(elsTime) { if ...
- h5 唤起app或跳转appStore
//唤起app通过唤端媒介(URL Scheme) //微信浏览器自6.3.x版本起禁用了大多数Scheme跳转功能,扫一扫目前可用 // URL 的组成: // [scheme:][// ...
- H5及微信中唤起app的解决方案
今天我们就来说说这个callapp-lib 我的接到的需求大概是这样的 如果检测到不是在app里面用webview打开的页面就会显示上面的立即打开按钮, 点击的话会判断是否在微信中, 如果在微信中打开 ...
- js在微信、微博、QQ、Safari唤起App的解决方案
首先看下完整的流程: 简单说下universal link 在iOS9之前,唤起方式和现在安卓是一个的,都是使用scheme进行唤起,这种方式有个小问题,每次唤起,都会给个提示:是否打开xx应用,这样 ...
- H5唤起APP一些坑
$(function () { function _openAppUrl(appUrl){ var ua = navigator.userAgent.toLocaleLowerCase(), open ...
- H5如何实现唤起APP
前言 写过hybrid的同学,想必都会遇到这样的需求,如果用户安装了自己的APP,就打开APP或跳转到APP内某个页面,如果没安装则引导用户到对应页面或应用商店下载.这里就涉及到了H5与Native之 ...
- 简话h5唤起本地app
在没接触这个功能之前,查询各种文档后也只是似懂非懂,做过之后,发现其实很简单,简言之就是通过一个iframe或者a标签来跳转app端提供的URL schema(至于这个URL schema的组成格式, ...
- 如何应用前端技术唤起app及判断用户来源及与原生交互的原理
做唤起时需要native端进行配合, h5唤起app这种需求是常见的.在移动为王的时代,h5在app导流上发挥着重要的作用. 目前我们采用的唤起方式是url scheme(iOS,Android平台都 ...
随机推荐
- name
问题 A: name 时间限制: 1 Sec 内存限制: 256 MB 题目描述 lpq同学最近突然对外国人的名字产生了兴趣,特别是外国女生的名字,于是他开始试图去认识一些国外的女生. 随着认识的女 ...
- Nginx详解六:Nginx基础篇之Nginx日志
1.Nginx日志类型 error.log:记录Nginx处理http请求的错误的状态,以及Nginx服务本身服务运行的错误的状态 access_log:记录通过Nginx的http请求的访问状态,用 ...
- C++ StrCat()
关于StrCat function,参考:https://msdn.microsoft.com/en-us/library/windows/desktop/bb759925(v=vs.85).aspx ...
- Spring-data-redis: serializer实例
spring-data-redis提供了多种serializer策略,这对使用jedis的开发者而言,实在是非常便捷.sdr提供了4种内置的serializer: JdkSerializationRe ...
- CHENGDU1-Python编程语言和PEP8规范
CHENGDU1-Python编程语言和PEP8规范 PEP8规范6条? 答:PEP8规范说白了就是一种规范,可以遵守,也可以不遵守,遵守PEP8可以让代码的可读性更高. 代码编排:---缩进,4个空 ...
- Java+selenium之WebDriver常见特殊情况如iframe/弹窗处理(四)
1. iframe 的处理 查找元素必须在对应的 ifarme 中查找,否则是找不到的 // 传入参数为 frame 的序号,从0开始 driver.switchTo().frame(Int inde ...
- HDU 2112 HDU Today(最短路径+map)
HDU Today Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- Git基础(一) 创建项目仓库
一.取得Git项目仓库的两种方法: 在现有目录中初始化仓库 git init 如果是在一个已经存在文件的文件夹(而不是空文件夹)中初始化Git仓库来进行版本控制的话,应该跟踪这些文件并提交,通过git ...
- [转] 前后端分手大师——MVVM 模式
之前对 MVVM 模式一直只是模模糊糊的认识,正所谓没有实践就没有发言权,通过这两年对 Vue 框架的深入学习和项目实践,终于可以装B了有了拨开云雾见月明的感觉. Model–View–ViewMod ...
- What's news in Visual Studio 2017
文字总结: 1.高级智能提示 在属性列表中输入 M C即可查询属性中包含字母m\c的属性 2.更快的导航查询,在Go To All中输入任意查询的字符,可快速查到任何包含关键字的文件 3.代码智能分 ...