浅谈Html5页面打开app的一些思考


Posted in HTML / CSS onMarch 30, 2020

1. 需求

前段时间开发项目,遇到了一个需求,简单来说,就是我们H5的页面有一个“在App中打开”的按钮,用户点击后,如果用户已经安装app,则直接打开app,如果用户没有安装app,那就跳转到下载app的页面

首先,在我的认知中,H5应该是没有能力检测到某一款app是否有安装的(如果有小伙伴知道如何检测,欢迎评论区告诉我,感谢!),所以我们需要一些技巧来完成判断app是否安装这一过程。

之后的步骤以安卓手机为例子介绍,目前ios9版本之后的系统不需要我们H5做这些判断app是否安装的流程(ios9之后可以通过提供一个通用链接(Universal link),做到没有安装app提示打开苹果应用商城,安装了app则直接跳转打开)

2. 关于scheme协议

scheme协议是一种页面内跳转协议,我们可以通过定制scheme协议,跳转到app中的想要跳转的各个页面。scheme协议是通过url的形式进行跳转的,所以我们H5也可以通过这个url去跳转到app内指定页面,这就是H5打开app的原理。

scheme的url格式类似: [scheme]://[host]/[path]?[query]

3. H5实现在App中打开的两种方法

3.1 单纯使用定时器判断

这种的方法的思路是,首先把我们要跳转的地址设置为与原生App同学一起定义好的scheme的url,之后,设置一个定时器,定时器里执行的逻辑是跳转到下载app页面,这样,如果用户手机没有安装app,就会在一段时间后跳转到下载页面。

核心代码如下:(可以使用iframe完成跳转,但需要考虑iframe是否在ios等设备中被允许)

const schemeUrl = 'xxx'
const downloadUrl = 'XXX'
const wait = 500
try {
    location = schemeUrl
    setTimeout(() => {
        location = downloadUrl
    }, wait)
} catch (e) {
    console.error(e)
}

存在的问题

上述实现方案的问题是,即使成功跳转到App,原先的H5页面也会在定时时间后,跳转到下载页面,这样体验很不好

3.2 使用window的hidden属性判断

这个方法的思路是,如果成功唤起了app,我们的H5页面被置于后台,window.hidden属性会变为true,可以通过这个属性变化来判断app有没有打开,没打开就跳转到下载页面,当然这里也用到定时器

核心代码如下:

function checkOutApp() {
    const schemeUrl = 'xxx'
    const downloadUrl = 'XXX'
    const wait = 1000
    // 是否进入后台
    const hidden = false
    location = schemeUrl
    // 如果一定时间内,页面没有隐藏,则跳转到下载页
    setTimeout(() => {
        if (!hidden) {
            location = downloadUrl
        }
    }, wait)
    // 页面可见性变化事件
    document.addEventListener("visibilitychange", function(){
        if (document.hidden) {
            hidden = true
        }
    });
}

存在的问题

目前一些安卓浏览器,在app存在时,会首先跳出一个确认框,询问用户是否打开app,只有用户同意时,才会跳转app,如果用户始终没有点击确认,最后还是会跳到下载页面,体验不好

4. 一些思考

鉴于上面说到的一些问题,个人觉得可以在交互中增加一个“去下载页面”的交互,如果用户没有安装app,一定时间后,首先提示用户“是否没有安装app,点击去下载”类似的按钮,用户点击跳转到下载页面,这样会不会更好呢。

到此这篇关于浅谈Html5页面打开app的一些思考的文章就介绍到这了,更多相关Html5打开app内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
使用CSS Grid布局实现网格的流动
Dec 30 HTML / CSS
使用CSS3和Checkbox实现JQuery的一些效果
Aug 03 HTML / CSS
CSS3实现曲线阴影和翘边阴影
May 03 HTML / CSS
CSS3关于z-index不生效问题的解决
Feb 19 HTML / CSS
CSS3 实现雷达扫描图的示例代码
Sep 21 HTML / CSS
HTML5样式控制示例代码
Nov 27 HTML / CSS
HTML5 Canvas中绘制矩形实例
Jan 01 HTML / CSS
详解HTML5 Canvas绘制时指定颜色与透明度的方法
Mar 25 HTML / CSS
H5调用相机拍照并压缩图片的实例代码
Jul 20 HTML / CSS
html5.2 dialog简介详解
Feb 27 HTML / CSS
html5视频媒体标签video的使用方法及完整参数说明详解
Sep 27 HTML / CSS
css3实现背景图片半透明内容不透明的方法示例
Apr 13 HTML / CSS
详解HTML5常用的语义化标签
Sep 27 #HTML / CSS
html5 移动端视频video的android兼容(去除播放控件、全屏)
Mar 26 #HTML / CSS
HTML5 Canvas实现放大镜效果示例
Mar 25 #HTML / CSS
HTML5 图片预加载的示例代码
Mar 25 #HTML / CSS
html2canvas截图空白问题的解决
Mar 24 #HTML / CSS
html5视频常用API接口的实战示例
Mar 20 #HTML / CSS
Html5页面上如何禁止手机虚拟键盘弹出
Mar 19 #HTML / CSS
You might like
php使用APC实现实时上传进度条功能
2015/10/26 PHP
php如何实现不借助IDE快速定位行数或者方法定义的文件和位置
2017/01/17 PHP
基于jquery实现图片广告轮换效果代码
2011/07/07 Javascript
javascript中typeof的使用示例
2013/12/19 Javascript
jquery 删除字符串最后一个字符的方法解析
2014/02/11 Javascript
基于JS实现无缝滚动思路及代码分享
2016/06/07 Javascript
JS简单生成两个数字之间随机数的方法
2016/08/03 Javascript
jQuery树形插件jquery.simpleTree.js用法分析
2016/09/05 Javascript
jfinal与bootstrap的登出实战详解
2017/11/27 Javascript
vue项目国际化vue-i18n的安装使用教程
2018/03/14 Javascript
微信小程序滑动选择器的实现代码
2018/08/10 Javascript
element-ui表格列金额显示两位小数的方法
2018/08/24 Javascript
用Object.prototype.toString.call(obj)检测对象类型原因分析
2018/10/11 Javascript
JS/HTML5游戏常用算法之追踪算法实例详解
2018/12/12 Javascript
ES10 特性的完整指南小结
2019/03/04 Javascript
微信小程序自定义头部导航栏(组件化)
2019/11/15 Javascript
微信小程序用户盒子、宫格列表的实现
2020/07/01 Javascript
Vue如何跨组件传递Slot的实现
2020/12/14 Vue.js
单利模式及python实现方式详解
2018/03/20 Python
浅谈pyqt5在QMainWindow中布局的问题
2019/06/21 Python
ERLANG和PYTHON互通实现过程详解
2019/07/05 Python
Python中url标签使用知识点总结
2020/01/16 Python
Python通过2种方法输出带颜色字体
2020/03/02 Python
django中的数据库迁移的实现
2020/03/16 Python
Django+Celery实现动态配置定时任务的方法示例
2020/05/26 Python
Python使用20行代码实现微信聊天机器人
2020/06/05 Python
Python中openpyxl实现vlookup函数的实例
2020/10/28 Python
HTML5+CSS3实现无插件拖拽上传图片(支持预览与批量)
2017/01/05 HTML / CSS
override和overload的区别
2016/03/09 面试题
毕业生个人求职的自我评价
2013/10/28 职场文书
关于元旦的广播稿
2014/02/16 职场文书
2014年科室工作总结
2014/11/20 职场文书
社区环境卫生倡议书
2015/04/29 职场文书
一条慢SQL语句引发的改造之路
2022/03/16 MySQL
使用pd.merge表连接出现多余行的问题解决
2022/06/16 Python
JS前端使用canvas实现扩展物体类和事件派发
2022/08/05 Javascript