IOS 开发之应用唤起实现原理详解

 更新时间:2016年12月31日 16:51:34   投稿:lqh  
这篇文章主要介绍了IOS 开发之应用唤起实现原理详解的相关资料,需要的朋友可以参考下

一、什么是iOS应用唤起

IOS中的应用唤起用来实现以下功能:在浏览器中可以通过某些方式打开IOS手机本地的app,如果该app没有安装可以跳转到该应用对应的App Store的下载页。 

二、App store下载页连接

App store中某个应用的下载页连接形如:https://itunes.apple.com/us/app/id399608199。在PC端浏览器打开该连接会跳转到应用详情页的PC端界面。在Safari中打开该连接,浏览器会询问是否在App Store中打开该连接,选择打开即会自动打开App Store并跳转到对应应用的下载界面。 

三、URL Schemes

URL Schemes和URL很类似,一个URL可以指向某个网站(如https://www.apple.com指向苹果官网),也可以指向该网站内部具体的某个页面(如https://www.apple.com/mac/指向苹果官网的Mac页面)。一个URL Schemes也可以指向某个APP(weixin://指向微信这个APP)或者APP内部的某个功能(weixin://dl/moments/指向微信朋友圈功能)。

基本URL Schemes指的是如weixin://的这部分。通过这个基本URL Schemes,可以打开某个IOS APP应用。比如在Safari的地址栏中输入weixin://,浏览器就会提示是否打开微信,选择打开,手机就会自动打开本地的微信应用。

 四、IOS应用唤起方法

1.直接跳转法(支持各个版本IOS系统)

最简单的方法,在页面中使用a标签制作一个按钮,让其href指向打开APP的基本URL Schemes即可。考虑到可能本地没有安装,这时需要通过js代码让浏览器跳转到对应的App Store下载页。可以设定一个合理的反映时间时间,如果超时还没有打开应用的话,就跳转到下载页面,可以使用setTimeout方法,代码如下:

$('a').click(function() { 
  location.href = 'weixin://'; 
  setTimeout(function() { 
    location.href = 'https://itunes.apple.com/us/app/id399608199'; 
  }, 500); 
} 

2.使用iframe(仅支持IOS8及其以下版本)

通过为body中添加一个隐藏的iframe,其内部的src设置成对应的连接,即可实现该功能,代码如下:

var url = { 
 open: 'weixin://', //对应的Scheme 
 down: 'https://itunes.apple.com/us/app/id399608199'  //对应的下载地址 
}; 
var iframe = document.createElement('iframe'); //创建一个iframe 
var body = document.body; 
iframe.style.cssText='display:none;width=0;height=0'; //设置该iframe为不可见的 
var timer = null; 
var openapp = document.getElementById('openapp'); 
openapp.addEventListener('click', function() { 
 body.appendChild(iframe);  //点击打开app按钮后,将这个iframe添加到body中 
 iframe.src = url.open; //设置iframe的src为weixin://,通过这个iframe进行跳转 
 timer = setTimeout(function() { 
  wondow.location.href = url.down; //500ms后跳转到下载界面 
 }, 500); 
}, false) 

3.使用Universal links(目前仅IOS9支持)

Universal links是IOS9新增的功能,它是一个普通的HTTP连接。通过Universal links,能够方便的通过传统的HTTP链接来启动APP(如果iOS设备上已经安装了app), 或者打开对应下载界面(iOS设备上没有安装app)。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • iOs迁至WKWebView跨过的一些坑

    iOs迁至WKWebView跨过的一些坑

    这篇文章主要给大家介绍了关于iOs迁至WKWebView跨过的一些坑,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-09-09
  • iOS图片放大的方式(transform和frame)

    iOS图片放大的方式(transform和frame)

    这篇文章主要介绍了iOS图片放大的两种方式,transform方式放大图片,从中心开始放大,另一种用frame改变宽高,详细内容请参考下文
    2016-04-04
  • iOS10 适配远程推送功能实现代码

    iOS10 适配远程推送功能实现代码

    这篇文章主要介绍了iOS10 适配远程推送功能实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 详解IOS宏与常量的使用(define,const)

    详解IOS宏与常量的使用(define,const)

    这篇文章主要介绍了详解IOS宏define与常量const的使用方法,适合IOS程序员参考,一起来学习下。
    2017-12-12
  • iOS开发实现下载器的基本功能(1)

    iOS开发实现下载器的基本功能(1)

    这篇文章主要为大家详细介绍了iOS开发实现下载器基本功能的相关资料,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • iOS自动生成表格效果的实现代码

    iOS自动生成表格效果的实现代码

    这篇文章主要为大家详细介绍了iOS自动生成表格效果的实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • iOS 数据结构之数组的操作方法

    iOS 数据结构之数组的操作方法

    这篇文章主要介绍了iOS 数据结构之数组的操作方法,非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2018-07-07
  • 浅析iOS给图片加水印的方法

    浅析iOS给图片加水印的方法

    在一些应用如微博中,为了防止用户图片被盗用,一般会在图片上加上水印,接下来就给大家分享一个iOS中给图片加水印的简单方法.一起来看看吧。
    2016-08-08
  • iOS开发傻瓜式微信支付的方法教程

    iOS开发傻瓜式微信支付的方法教程

    最近因为工作的需要,要开发微信支付,发现网上的很多教程过于复杂,索性自己写一篇,所以下面这篇文章主要跟大家分享了关于iOS开发傻瓜式微信支付的方法教程,文中通过示例代码介绍的非常详细,需要的朋友们下面来一起看看吧。
    2017-07-07
  • iOS 把图片保存到相册,并获取图片文件名的实例

    iOS 把图片保存到相册,并获取图片文件名的实例

    下面小编就为大家分享一篇iOS 把图片保存到相册,并获取图片文件名的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2017-12-12

最新评论