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 相关文章推荐
详解Vue3 Teleport 的实践及原理
Dec 02 Vue.js
vue使用exif获取图片旋转,压缩的示例代码
Dec 11 Vue.js
vue中配置scss全局变量的步骤
Dec 28 Vue.js
Vue.extend 登录注册模态框的实现
Dec 29 Vue.js
vue实现图书管理系统
Dec 29 Vue.js
vue+vant 上传图片需要注意的地方
Jan 03 Vue.js
vue3.0中友好使用antdv示例详解
Jan 05 Vue.js
vue使用vue-quill-editor富文本编辑器且将图片上传到服务器的功能
Jan 13 Vue.js
Vue实现圆环进度条的示例
Feb 06 Vue.js
vue基于Teleport实现Modal组件
May 31 Vue.js
vue使用Google Recaptcha验证的实现示例
Aug 23 Vue.js
vue数据字典取键值项目的字典问题
Apr 12 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下10件你也许并不了解的事情
2008/09/11 PHP
php面向对象全攻略 (十) final static const关键字的使用
2009/09/30 PHP
php rmdir使用递归函数删除非空目录实例详解
2016/10/20 PHP
如何在Mozilla Gecko 用Javascript加载XSL
2007/01/09 Javascript
拖拉表格的JS函数
2008/11/20 Javascript
基于jquery的jqDnR拖拽溢出的修改
2011/02/12 Javascript
js遍历、动态的添加数据的小例子
2013/06/22 Javascript
JS小功能(操作Table--动态添加删除表格及数据)实现代码
2013/11/28 Javascript
javascript中数组array及string的方法总结
2014/11/28 Javascript
jquery显示loading图片直到网页加载完成的方法
2015/06/25 Javascript
JavaScript程序开发之JS代码放置的位置
2016/01/15 Javascript
jquery的ajax提交form表单的两种方法小结(推荐)
2016/05/25 Javascript
原生js三级联动的简单实现代码
2016/06/07 Javascript
AngularJS入门教程之双向绑定详解
2016/08/18 Javascript
详解jQuery停止动画——stop()方法的使用
2016/12/14 Javascript
H5图片压缩与上传实例
2017/04/21 Javascript
jQuery实现frame之间互通的方法
2017/06/26 jQuery
Bootstrap4 gulp 配置详解
2019/01/06 Javascript
微信小程序基于picker实现级联菜单
2019/02/15 Javascript
Vue路由模块化配置的完整步骤
2019/08/14 Javascript
js实现自动播放匀速轮播图
2020/02/06 Javascript
[03:40]DOTA2抗疫特别篇《英雄年代》
2020/02/28 DOTA
Python使用新浪微博API发送微博的例子
2014/04/10 Python
对numpy中array和asarray的区别详解
2018/04/17 Python
使用Python3内置文档高效学习以及官方中文文档
2019/05/19 Python
python向企业微信发送文字和图片消息的示例
2020/09/28 Python
Mavi牛仔裤美国官网:土耳其著名牛仔品牌
2016/09/24 全球购物
Draper James官网:知名演员瑞茜·威瑟斯彭所创品牌
2017/10/25 全球购物
美国温暖商店:The Warming Store
2018/12/15 全球购物
交通安全教育制度
2014/02/02 职场文书
教师中国梦演讲稿
2014/04/23 职场文书
小学生演讲稿大全
2014/04/25 职场文书
关于安全的广播稿
2014/10/23 职场文书
生活委员竞选稿
2015/11/21 职场文书
vue3中的组件间通信
2021/03/31 Vue.js
分析MySQL优化 index merge 后引起的死锁
2022/04/19 MySQL