H5唤起原生应用

转载 2017年01月03日 09:33:08

解决问题:当用户在手机浏览器中点击一个按钮时,如果手机上已经安装该应用,则直接打开,如果没有安装,则转向应用下载页面。

实现方式

H5实现

链接格式如下

1
<a href="[scheme]://[host]/[path]?[query]"> 唤起应用 </a>

各个项目含义如下所示:

  • scheme:唤起协议 ※详细后述
  • host: 唤起指定host
    • path: 协议路径※没有也可以
    • query: 一些参数※没有也可以

终端未安装APP

终端如果已经安装我们的应用,这个时候可以直接唤起原生应用;终端如果没有安装我们的应用,这时我们需要引导用户去安装。

JavaScript实现源码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<a id="call-app" href="javascript:;" > Start or Download </a><br/><br/>
<input id="download-app" type="hidden" name="storeurl" value="http://jd.com/8JZ5OO">

<script>
(function(){
var ua = navigator.userAgent.toLowerCase();
var t;
var config = {
/*scheme:必须*/
scheme_IOS: 'schemedemo://',
scheme_Adr: 'schemedemo://ihongqiqu.com/test/scheme?name=google&page=1',
download_url: document.getElementById('download-app').value,
timeout: 600
};

function openclient() {
var startTime = Date.now();

var ifr = document.createElement('iframe');

ifr.src = ua.indexOf('os') > 0 ? config.scheme_IOS : config.scheme_Adr;
ifr.style.display = 'none';
document.body.appendChild(ifr);

var t = setTimeout(function() {
var endTime = Date.now();

if (!startTime || endTime - startTime < config.timeout + 200) {
window.location = config.download_url;
} else {

}
}, config.timeout);

window.onblur = function() {
clearTimeout(t);
}
}
window.addEventListener("DOMContentLoaded", function(){
document.getElementById("call-app").addEventListener('click',
openclient, false);
}, false);
})()
</script>

APP实现

AndroidManifest中添加配置

1
2
3
4
5
6
7
8
<activity android:name=".SchemeActivity">
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.BROWSABLE" />
<category android:name="android.intent.category.DEFAULT" />
<data android:scheme="schemedemo" />
</intent-filter>
</activity>

DATA标签中匹配原则如下:

  • android:scheme : 唤起协议
  • android:host : 唤起host,只有置顶的host才可被唤起
  • android:pathPrefix : 唤起的路径,对路径进一步的过滤

Activity中接受唤起协议的数据:

1
2
3
4
5
6
7
8
9
10
11
12
13
Uri uri = getIntent().getData();
StringBuilder sb = new StringBuilder();
// 唤起链接
sb.append("string : ").append(getIntent().getDataString()).append("\n");
sb.append("scheme : ").append(uri.getScheme()).append("\n");
sb.append("host : ").append(uri.getHost()).append("\n");
sb.append("port : ").append(uri.getPort()).append("\n");
sb.append("path : ").append(uri.getPath()).append("\n");
// 接收唤起的参数
sb.append("name : ").append(uri.getQueryParameter("name")).append("\n");
sb.append("page : ").append(uri.getQueryParameter("page"));

tv_data.setText(sb.toString());

测试资源

唤起源码
测试地址
正式地址

项目源码

https://github.com/jingle1267/AndroidSchemeDemo


本文地址 http://ihongqiqu.com/2015/12/03/html-call-native-app/ 作者为 Zhenguo

相关文章推荐

【H5+ & Quick-cocos2dx整合】之iOS 一 创建原生应用

概述 HTML5+ Html5 plus: HTML5+是中国HTML5产业联盟的扩展规范,基于HTML5扩展了大量调用设备的能力,使得web语言可以想原生语言一样强大。扩展30多种能力,包括二维码、...

前端学习总结(十二)ionic——媲美原生的h5跨平台移动应用开发框架

一 ionic简介 ionic是一个专注于用WEB开发技术,基于HTML5创建类似于手机平台原生应用的一个开发框架。绑定了AngularJS和Sass。这个框架的目的是从web的角度开发手机应用,基...

iOS原生H5交互开发

  • 2016年03月05日 19:33
  • 99KB
  • 下载

Android 中最简单的实现 HTML(H5)调用native原生页面的方法

先简单描述一下Android 中最简单的实现 HTML调用native原生页面的流程: 1、先让Activity注册实现schema 2、Activity实现可以接收schema传过来的参数的方法 3...

H5页面仿原生列表会话左滑显示删除键/编辑键--局部滑动

H5页面仿原生列表会话左滑显示删除键/编辑键--局部滑动 页面滑动原理主要是用了一个左滑手势,需要在页面中引入jquery.mobile-1.4.5.min.js这个插件。 页面文件之间的管理用的是...

Appium Android 元素定位方法 原生+H5

转载地址 http://blog.csdn.net/vivian_ljx/article/details/54410024 这篇文章写得太详细了,都使用过,但很久不用之后就会忘,必须转载分享...

H5实现APP和原生方式有多大差距,多少坑?JS才是王道!

纯H5的APP,虽然开发起来要比纯原生开发畅快的多,但最终效果和性能还是和原生比起来还是有很多问题,主要聚集在以下几个方面: 1、动画 动画有很多种,比如侧边栏菜单的滑入滑出、元素的响应动...

混合开发原生嵌套H5页面

近段时间一直在替换原生页面,也快告一段落了。现在谈谈自己的心德与看法,如有什么错误的观点请指正,多多包涵。 所谓的混合开发或者是混合模式,无非就是把H5页面嵌套在原生app里。当我们打开app时原生页...

Appium Android 元素定位方法 原生+H5

APPIUM Android 元素定位方式,原生+H5 1.定位元素应用元素   1.1通过id定位元素 Android里面定位的id一般为resrouce-id: 代码可以这样写...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:H5唤起原生应用
举报原因:
原因补充:

(最多只允许输入30个字)