文章详情页
javascript - H5唤醒App
浏览:154日期:2022-12-25 17:31:43
问题描述
H5唤醒App,如何检测到是否成功唤醒?现在的处理是:
点击后,500ms没成功就跳转到下载页面。
在ios下,点击后,直接打开了App;但页面在继续执行,不管是否安装了App都会跳转到下载页面。
需求是,如果成功打开App,就不能跳转到下载页面。
现在的思路是通过判断页面是否可见或者失去焦点,来判断是否打开了App,故做了如下尝试:
判断document.hasFocus(),但其返回值一直为true。
监听visibilitychange事件;visibilitychange在安卓下可以,在ios下只有在浏览器内切换页面会触发,点击home键回到桌面不触发。
监听pageshow事件,貌似只有重载页面时才会触发,不能满足需求。
问题解答
回答1:iOS下用 Universal Links.
什么setTimeout visibilityChange 都是 hack 的做法,iOS9+ 还有 universal links这种官方的解决方案,安卓上千奇百怪的浏览器就惨了,若是调起了自家 App 仍然跳转到下载页面,那就跳吧,能怎样,与其过度扣这种前端没法解决只能 hack 的细节,不如把产品做好,用户安装了你家 App,他要用 App 自己自然会用。
标签:
JavaScript
相关文章:
1. docker-compose 为何找不到配置文件?2. python的bs4如何筛选出h1标签中的内容3. angular.js - 通过数据中children的个数自动生成能点击展开的div4. css - 使用blur()滤镜为什么有透明的效果5. docker gitlab 如何git clone?6. android - 安卓做前端,PHP做后台服务器 有什么需要注意的?7. 前端 - css3 3d效果问题8. java - spring-data Jpa 不需要执行save 语句,Set字段就可以自动执行保存的方法?求解9. javascript - 移动端H5页面禁止缩放了,在浏览器上仍然可以缩放10. javascript - JS设置Video视频对象的currentTime时出现了问题,IE,Edge,火狐,都可以设置,反而chrom却...
排行榜
