vue中h5端打开app(判断是安卓还是苹果)


Posted in Vue.js onFebruary 26, 2021

1.开发环境 vue+vant

2.电脑系统 windows10专业版

3.在h5端开发的过程中,我们经常需要点击一个按钮来判断用户使用安装了app(首先判断是安卓还是苹果,然后判断是否安装了app,如果没有安装则跳转到下载页面,如果安装了则打开)。

4.废话不多说,直接上代码:

<div class="xiding-r" @click="openapp">
 Open APP
</div>

5.在methods中添加如下代码:

openapp() {
  var u = navigator.userAgent,
   app = navigator.appVersion;
  var isAndroid = u.indexOf("Android") > -1 || u.indexOf("Linux") > -1;
  var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/);
  if (isAndroid) {
   // alert("我是安卓");
   this.android();
  }
  if (isIOS) {
   // alert("我是苹果");
  }
  },
android() {
  var _clickTime = new Date().getTime();
  window.location.href = 'zhihu://'; /***打开app的协议,有安卓同事提供***/

  //启动间隔20ms运行的定时器,并检测累计消耗时间是否超过3000ms,超过则结束
  var _count = 0, intHandle;
  intHandle = setInterval(function () {
   _count++;
   var elsTime = new Date().getTime() - _clickTime;
   if (_count >= 100 || elsTime > 5000) {
   console.log(_count)
   console.log(elsTime)
   clearInterval(intHandle);
   //检查app是否打开
   if (document.hidden || document.webkitHidden) {
    // 打开了
    window.location.href = "zhihu://";
    // alert('打开了');
    window.close();
    // return;
   } else {
    // 没打开
    // alert('没打开');
    window.location.href = "";//下载链接
   }
   }
  }, 20);
  },

5.注意:在这个案例中我是用的知乎的例子:

vue中h5端打开app(判断是安卓还是苹果)

6.注意

使用Custom URL Scheme的好处就是,你可以在其他程序中通过这个url打开应用程序。如果A应用程序注册了一个 url scheme:myApp,那么就在mobile浏览器中就可以通过<a href ="myApp://">打开你的应用程序。请注意,IOS中如果系统注册了 url schemen且安装了那个应用程序,通过上面那种网页的方式就可以打开应用程序(亲测有效)。注意:IOS中不能注册为http://xxx这样的url scheme,而android是可以的。

到此这篇关于vue中h5端打开app(判断是安卓还是苹果)的文章就介绍到这了,更多相关vue中h5端打开app 内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
一篇超完整的Vue新手入门指导教程
Nov 18 Vue.js
Vue3配置axios跨域实现过程解析
Nov 25 Vue.js
vue从后台渲染文章列表以及根据id跳转文章详情详解
Dec 14 Vue.js
vue+element table表格实现动态列筛选的示例代码
Jan 14 Vue.js
Vue实现摇一摇功能(兼容ios13.3以上)
Jan 26 Vue.js
vue监听键盘事件的相关总结
Jan 29 Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 Vue.js
Vue和Flask通信的实现
May 19 Vue.js
vue组件冲突之引用另一个组件出现组件不显示的问题
Apr 13 Vue.js
vue项目配置sass及引入外部scss文件
Apr 14 Vue.js
vue 自定义组件添加原生事件
Apr 21 Vue.js
关于vue-router-link选择样式设置
Apr 30 Vue.js
Vue基本指令实例图文讲解
Feb 25 #Vue.js
vue常用高阶函数及综合实例
Feb 25 #Vue.js
详解vite+ts快速搭建vue3项目以及介绍相关特性
Feb 25 #Vue.js
基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件功能
Feb 23 #Vue.js
用vite搭建vue3应用的实现方法
Feb 22 #Vue.js
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 #Vue.js
vue-cli 3如何使用vue-bootstrap-datetimepicker日期插件
Feb 20 #Vue.js
You might like
我的论坛源代码(七)
2006/10/09 PHP
php实现的MySQL通用查询程序
2007/03/11 PHP
php通过数组实现多条件查询实现方法(字符串分割)
2014/05/06 PHP
五款PHP代码重构工具推荐
2014/10/14 PHP
php 问卷调查结果统计
2015/10/08 PHP
jQuery学习之prop和attr的区别示例介绍
2013/11/15 Javascript
JQuery使用$.ajax和checkbox实现下次不在通知功能
2015/04/16 Javascript
jQuery实现类似老虎机滚动抽奖效果
2015/08/06 Javascript
Vue.js双向绑定实现原理详解
2016/12/22 Javascript
JQuery Ajax 异步操作之动态添加节点功能
2017/05/24 jQuery
详解从Vue.js源码看异步更新DOM策略及nextTick
2017/10/11 Javascript
vue-for循环嵌套操作示例
2019/01/28 Javascript
Vue实现商品详情页的评价列表功能
2019/09/04 Javascript
VueCli生产环境打包部署跨域失败的解决
2020/11/13 Javascript
JS实现点击掉落特效
2021/01/29 Javascript
详解python使用turtle库来画一朵花
2019/03/21 Python
OpenCV HSV颜色识别及HSV基本颜色分量范围
2019/03/22 Python
如何利用Python模拟GitHub登录详解
2019/07/15 Python
python3的数据类型及数据类型转换实例详解
2019/08/20 Python
python如何实现单链表的反转
2020/02/10 Python
Anaconda和ipython环境适配的实现
2020/04/22 Python
Python如何绘制日历图和热力图
2020/08/07 Python
东方电视购物:东方CJ
2016/10/12 全球购物
Carrs Silver官网:英国著名的银器品牌
2020/08/29 全球购物
物流仓储计划书
2014/01/10 职场文书
运动会解说词100字
2014/01/31 职场文书
社区服务活动总结
2014/05/07 职场文书
演讲稿的写法
2014/05/19 职场文书
廉洁校园实施方案
2014/05/25 职场文书
查摆问题对照检查材料
2014/08/28 职场文书
2015年仓管员工作总结
2015/04/21 职场文书
2015年保险业务员工作总结
2015/05/27 职场文书
幼儿园小班班务总结
2015/08/03 职场文书
2016年秋季运动会通讯稿
2015/11/25 职场文书
Python万能模板案例之matplotlib绘制直方图的基本配置
2022/04/13 Python
深入理解 Golang 的字符串
2022/05/04 Golang