js判断手机是否下载APP

场景描述

在APP内嵌H5页面中,用户在APP外打开该页面并触发相应事件,若用户安装了该APP则调起APP,若用户未安装APP,则Android用户引导至应用宝下载,iOS用户引导至App Store下载

前期准备

由Android和iOS开发同事提供打开APP对应的url

let androidData = 'android://url/android?operateType=3&configs='+baseUrl 
let iosData = 'ios://url/ios?operateType=3&configs='+baseUrl

判断打开页面系统类型

this.isAndroid = user.indexOf("Android") > -1 || user.indexOf("Adr") > -1;
判断方法

1.获取进入方法时间戳,
2.window.location.href尝试打开
3.定时器获取第二次时间戳
4.计算时间差,时间差在一定范围内则未安装

缺点

1.时间差由自己决定,但是会受到网络、手机卡顿等因素影响
2.Android在浏览器询问打开时,若点击过慢会判断为未安装
3.ios基本不能判断出
4.微信浏览器内只有微信白名单才能直接打开APP,不在微信白名单则需要引导至浏览器打开

代码实现
   let data = { // 打开APP携带的参数
     "className":"webView",
     "classPath":"webView",
   }
   let url = JSON.stringify(data)  // 参数转为json字符串
   let baseUrl = encode64(utf16to8(url)) // 数据加码
   let androidData = 'android://url/android?operateType=3&configs='+baseUrl // Android路径
   let iosData = 'ios://url/ios?operateType=3&configs='+baseUrl //iOS路径
   var openTime = new Date();//获取当前时间戳
   if (this.isAndroid) { // 判断当前手机系统为Android
     window.setTimeout(function () {
       if ((new Date()) - openTime < 3100) { 
       	 // 响应延迟小于100ms 认为未安装APP,前去应用宝下载
         window.location.href = "https://sj.qq.com/myapp/detail.htm?apkName=****";
       }
       else{
         window.close()
       }
     }, 3000);
     window.location.href = androidData // 尝试打开APP
   } else{ // 判断当前手机系统为iOS
     window.setTimeout(function () {
       if ((new Date()) - openTime < 3100) { 
        // 响应延迟小于100ms 认为未安装APP,前去App Store下载
         window.location.href = 'http://itunes.apple.com/us/app/******';
       }
       else{
         window.close()
       }
     }, 3000);
     window.location.href = iosData
   }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在浏览器中判断是否安装某个应用,可以使用JavaScript来实现。一种常用的方法是通过检测某个特定的URL Scheme是否可用来判断应用是否安装。URL Scheme是一种应用程序的自定义协议,可以用来在浏览器中直接打开应用。 具体的实现代码如下所示: ```javascript function isAppInstalled() { var appScheme = "your-app-scheme"; // 替换为你的应用的URL Scheme var appLink = "your-app-link"; // 替换为你的应用的下载链接 var iframe = document.createElement("iframe"); iframe.src = appScheme + "://"; iframe.style.display = "none"; document.body.appendChild(iframe); setTimeout(function() { document.body.removeChild(iframe); window.location.href = appLink; }, 500); } ``` 在上述代码中,我们创建了一个隐藏的iframe元素,并将其src属性设置为应用的URL Scheme。如果应用已安装,则会成功打开应用;如果应用未安装,则会触发iframe的error事件,此时我们可以通过setTimeout函数跳转到应用的下载链接。 需要注意的是,你需要将代码中的"your-app-scheme"替换为你的应用的URL Scheme,将"your-app-link"替换为你的应用的下载链接。 此外,为了使浏览器能够正确地识别应用的URL Scheme,你还需要在应用的配置文件中进行相应的设置。具体的设置方法可以参考你所使用的平台和开发工具的文档。 引用\[2\]提供了一个示例的JavaScript代码,可以用来判断手机是否安装某个应用,并打开该应用。你可以根据自己的需求进行适当的修改和调整。 请注意,具体的URL Scheme和配置文件设置可能因应用和平台而异,以上仅为一种常见的实现方法。 #### 引用[.reference_title] - *1* *2* *3* [手机浏览器下判断是否安装app,并判断是否打开该应用](https://blog.csdn.net/pjk1129/article/details/44982723)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值