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+iview实现文件上传
Nov 17 Vue.js
Vue如何循环提取对象数组中的值
Nov 18 Vue.js
Vue项目如何引入bootstrap、elementUI、echarts
Nov 26 Vue.js
vue+element实现动态加载表单
Dec 13 Vue.js
Vue实现点击当前行变色
Dec 14 Vue.js
详解Vue2的diff算法
Jan 06 Vue.js
vue组件的路由高亮问题解决方法
May 11 Vue.js
一文带你理解vue创建一个后台管理系统流程(Vue+Element)
May 18 Vue.js
vue实现滑动解锁功能
Mar 03 Vue.js
VUE使用draggable实现组件拖拽
Apr 06 Vue.js
如何优化vue打包文件过大
Apr 13 Vue.js
vue2的 router在使用过程中遇到的一些问题
Apr 13 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 parse_url 一个好用的函数
2009/10/03 PHP
PHP+JS三级菜单联动菜单实现方法
2016/02/24 PHP
php  单例模式详细介绍及实现源码
2016/11/05 PHP
yii2.0整合阿里云oss删除单个文件的方法
2017/09/19 PHP
一些javascript一些题目的解析
2010/12/25 Javascript
jquery如何通过name名称获取当前name的value值
2013/12/20 Javascript
手写的一个兼容各种浏览器的javascript getStyle函数(获取元素的样式)
2014/06/06 Javascript
Bootstrap每天必学之简单入门
2015/11/19 Javascript
浅谈angular2路由预加载策略
2017/10/04 Javascript
20个最常见的jQuery面试问题及答案
2018/05/23 jQuery
从组件封装看Vue的作用域插槽的实现
2019/02/12 Javascript
layer.open的自适应及居中及子页面标题的修改方法
2019/09/05 Javascript
js实现tab栏切换效果
2020/08/02 Javascript
Openlayers实现图形绘制
2020/09/28 Javascript
[04:14]从西雅图到上海——玩家自制DOTA2主题歌曲应援TI9
2019/07/11 DOTA
python基础教程之循环介绍
2014/08/29 Python
Python批量查询域名是否被注册过
2017/06/21 Python
python 实时得到cpu和内存的使用情况方法
2018/06/11 Python
python获取指定字符串中重复模式最高的字符串方法
2018/06/29 Python
Python变量类型知识点总结
2019/02/18 Python
Python 限制线程的最大数量的方法(Semaphore)
2019/02/22 Python
python中如何使用分步式进程计算详解
2019/03/22 Python
pandas将多个dataframe以多个sheet的形式保存到一个excel文件中
2019/10/10 Python
python实现计算器功能
2019/10/31 Python
tensorflow实现测试时读取任意指定的check point的网络参数
2020/01/21 Python
Django关于admin的使用技巧和知识点
2020/02/10 Python
python 函数嵌套及多函数共同运行知识点讲解
2020/03/03 Python
python爬虫开发之Beautiful Soup模块从安装到详细使用方法与实例
2020/03/09 Python
Keras之fit_generator与train_on_batch用法
2020/06/17 Python
CSS中垂直居中的简单实现方法
2015/07/06 HTML / CSS
建筑工程专业毕业生自荐信
2013/10/19 职场文书
语文教育专业应届生求职信
2013/11/23 职场文书
不打扫卫生检讨书
2014/02/12 职场文书
2014年党风廉政工作总结
2014/12/03 职场文书
公路施工安全责任书
2015/05/08 职场文书
python Polars库的使用简介
2021/04/21 Python