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的mixin策略
Nov 19 Vue.js
vue-drawer-layout实现手势滑出菜单栏
Nov 19 Vue.js
Vue3配置axios跨域实现过程解析
Nov 25 Vue.js
vue 在单页面应用里使用二级套嵌路由
Dec 19 Vue.js
vue el-upload上传文件的示例代码
Dec 21 Vue.js
全面解析Vue中的$nextTick
Dec 24 Vue.js
vue+elementui通用弹窗的实现(新增+编辑)
Jan 07 Vue.js
vue3中轻松实现switch功能组件的全过程
Jan 07 Vue.js
vue实现按钮切换图片
Jan 20 Vue.js
详解Vue的七种传值方式
Feb 08 Vue.js
Vue实现tab导航栏并支持左右滑动功能
Jun 28 Vue.js
vue 把二维或多维数组转一维数组
Apr 24 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
浅谈php和js中json的编码和解码
2016/10/24 PHP
javascript之大字符串的连接的StringBuffer 类
2007/05/08 Javascript
javaScript 简单验证代码(用户名,密码,邮箱)
2009/09/28 Javascript
jquery 操作表格实现代码(多种操作打包)
2011/03/20 Javascript
在JS数组特定索引处指定位置插入元素的技巧
2014/08/24 Javascript
JavaScript对Cookie进行读写操作实例
2015/07/25 Javascript
javascript中判断json的方法总结
2015/08/27 Javascript
详解AngularJS控制器的使用
2016/03/09 Javascript
拥有一个属于自己的javascript表单验证插件
2016/03/24 Javascript
JavaScript中的一些隐式转换和总结(推荐)
2017/12/22 Javascript
Vue路由模块化配置的完整步骤
2019/08/14 Javascript
javascript将扁平的数据转为树形结构的高效率算法
2020/02/27 Javascript
详解VUE中的插值( Interpolation)语法
2020/10/18 Javascript
如何在VUE中使用vue-awesome-swiper
2021/01/04 Vue.js
[54:26]完美世界DOTA2联赛PWL S3 Forest vs Rebirth 第一场 12.10
2020/12/12 DOTA
python和pyqt实现360的CLable控件
2014/02/21 Python
在Python的Flask框架中实现全文搜索功能
2015/04/20 Python
Python编程pygal绘图实例之XY线
2017/12/09 Python
Python实现学校管理系统
2018/01/11 Python
python时间序列按频率生成日期的方法
2019/05/14 Python
Pycharm如何打断点的方法步骤
2019/06/13 Python
Python3标准库之dbm UNIX键-值数据库问题
2020/03/24 Python
如何利用Python动态模拟太阳系运转
2020/09/04 Python
利用css3径向渐变做一张优惠券的示例
2018/03/22 HTML / CSS
一款html5 canvas实现的图片玻璃碎片特效
2014/09/11 HTML / CSS
巴西男士胡须和头发护理产品商店:Beard
2017/11/13 全球购物
联想英国官网:Lenovo英国
2019/07/17 全球购物
主管竞聘书范文
2014/03/31 职场文书
《蜗牛的奖杯》教后反思
2014/04/24 职场文书
学校安全管理责任书
2014/07/23 职场文书
护士先进个人总结
2015/02/13 职场文书
因个人工作失误检讨书
2019/06/21 职场文书
大学生饮品店创业计划书范文
2019/07/10 职场文书
Java8 Stream API 提供了一种高效且易于使用的处理数据的方式
2022/04/13 Java/Android
Nginx配置之禁止指定IP访问
2022/05/02 Servers
JavaScript正则表达式实现注册信息校验功能
2022/05/30 Java/Android