扣丁学堂简述如何通过H5(浏览器WebView其他)唤起本地APP(二)

上篇文章扣丁学堂小编给大家分享了通过H5(浏览器/WebView/其他)唤起本地APP的一种方式,本篇文章小编再给大家分享另一种方式,下面和小编一起来看一下吧。

扣丁学堂简述如何通过H5(浏览器WebView其他)唤起本地APP(二)

HTML5培训

第二种方式:

既然通过在href配置schema协议不行,那就只能通过js代码来实现了,只有这样才能根据判断实现app有的时候就打开,没有的时候就跳转到下载链接下载。

我们知道,js是无法判断手机是否安装了某款app的,所以我们只能够曲线救国了,我们可以获取时间如果,长时间不能呼起app则默认为没有安装这款app,然后跳转到下载页。当然这不是我想出来的,是网上的各位大佬的想法。在这里又要细分为两种情况了。

1、直接唤醒

说明:通过h5可换醒app,如访问一个URL,点击按钮,打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面,通过点击的方式兼容性较好,如果安装了app,在手机各大浏览器(360浏览器、uc浏览器、搜狗浏览器、QQ浏览器、百度浏览器 )和QQ客户端中,能唤醒。微信、新浪微博客户端、腾讯微博客户端无法唤醒。

代码如下:

<html xmlns=http://www.w3.org/1999/xhtml>

<head>

<meta http-equiv=Content-Type content="text/html;charset=utf-8">

<head>

<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>

<title>点击唤醒demo</title>

</head>

<body>

<style>

#zjmobliestart{font-size:40px;}

</style>

<!--

说明:通过h5可换醒app,如访问一个URL,点击按钮,打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面,通过点击的方式。兼容性较好,如果安装了app,在手机各大浏览器(360浏览器 uc浏览器 搜狗浏览器 QQ浏览器 百度浏览器 )和QQ客户端中,能唤醒。微信 新浪微博客户端 腾讯微博客户端无法唤醒。

-->

<a href="zjmobile://platformapi/startapp" id="zjmobliestart" target="_blank">唤醒浙江移动手机营业厅!</a>

<script type="text/javascript">

function applink(){

return function(){

var clickedAt = +new Date;

setTimeout(function(){

!window.document.webkitHidden && setTimeout(function(){

if (+new Date - clickedAt < 2000){

window.location = 'https://itunes.apple.com/us/app/zhe-jiang-yi-dong-shou-ji/id898243566#weixin.qq.com';

}

}, 500);

}, 500)

};

}

document.getElementById("zjmobliestart").onclick = applink();

</script>

</body>

</html>

2、点击唤醒

说明:通过h5可换醒app,如访问一个URL就能直接打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面。兼容性一般:在手机各大浏览器(360浏览器、uc浏览器、搜狗浏览器 QQ浏览器、百度浏览器 )能唤醒。微信、QQ客户端、新浪微博客户端、 腾讯微博客户端无法唤醒。

代码如下:

<!Doctype html>

<html xmlns=http://www.w3.org/1999/xhtml>

<head>

<meta http-equiv=Content-Type content="text/html;charset=utf-8">

<head>

<script src="http://libs.baidu.com/jquery/1.9.0/jquery.js"></script>

<title>直接唤醒demo</title>

</head>

<body>

<style>

#zjmobliestart{font-size:40px;}

</style>

<!--

说明:通过h5可换醒app,如访问一个URL就能直接打开应用,如果该应用APP没有安装,那么直接跳转到App Store的APP下载页面

兼容性一般:在手机各大浏览器(360浏览器 uc浏览器 搜狗浏览器 QQ浏览器 百度浏览器 )能唤醒。微信 QQ客户端 新浪微博客户端 腾讯微博客户端无法唤醒。

-->

<p id="zjmobliestart">唤醒浙江移动手机营业厅!</p>

<script type="text/javascript">

function applink(){

window.location = 'zjmobile://platformapi/startapp';

var clickedAt = +new Date;

setTimeout(function(){

!window.document.webkitHidden && setTimeout(function(){

if (+new Date - clickedAt < 2000){

window.location = 'https://itunes.apple.com/us/app/zhe-jiang-yi-dong-shou-ji/id898243566#weixin.qq.com';

}

}, 500);

}, 500)

}

applink();

</script>

</body>

</html>

还有的就是以为我是要在app里面通过加载webview的形式来唤起本地的app,这里也记录一下,代码如下:

webView.setWebViewClient(new WebViewClient(){

@Override public boolean shouldOverrideUrlLoading(WebView view, String url) {

Uri uri=Uri.parse(url);

if(uri.getScheme().equals("abraham")&&uri.getHost().equals("jingewenku.com")){

String arg0=uri.getQueryParameter("arg0");

String arg1=uri.getQueryParameter("arg1");

}else{

view.loadUrl(url);

} return true;

}});

以上就是小编给大家分享的通过H5(浏览器/WebView/其他)唤起本地APP的方法,希望对小伙伴们有所帮助。想要了解更多内容的小伙伴可以登录扣丁学堂官网咨询,扣丁学堂是专业的HTML5培训机构,不仅有专业的老师和与时俱进的课程体系,还有大量的,想要学好HTML5开发的小伙伴快快行动吧。

相关推荐