点击一个按钮,如果手机有安装app的话直接打开app,否则跳转到应用市场下载该app

编程知识 更新时间:2023-05-02 19:40:02

最近在做一个这样的功能,前端网页点击按钮时,如果用户手机有安装该app,则直接打开app;否则就跳到应用市场下载。代码如下:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
	</head>
	<body id="body">
		<a href="javascript:;" id="openApp" style="font-size: 30px;">打开客户端</a>
	</body>	
	<script type="text/javascript">
	document.getElementById('openApp').onclick = function(e) {
		//ios
		if(navigator.userAgent.match(/(iPhone|iPod|iPad);?/i)) {

			var browser = navigator.userAgent.toLowerCase();

			if(browser.match(/micromessenger/i)) {
				//微信内置浏览器
				window.location.href ="hengtaixin://";
				window.setTimeout(function() {
					window.location.href = "https://itunes.apple/us/app/cheng-shi-gao-er-fu/id1008696844?mt=8&uo=4";
				}, 1000)
				return
			} else {
				window.location.href ="hengtaixin://"; //ios app协议,由ios同事提供
				window.setTimeout(function() {
					window.location.href = "https://itunes.apple/us/app/cheng-shi-gao-er-fu/id1008696844?mt=8&uo=4";
				}, 2000)
				return
			}
		}

		if(navigator.userAgent.match(/android/i)) {
			//Android
			window.location.href = "app://city_golf";//安卓协议,由安卓同事提供
			window.setTimeout(function() {
				
				window.location.href = "http://a.app.qq/o/simple.jsp?pkgname=gr eenjoy.golf.app&g_f=991653"
			}, 2000)
			return
		}

	};
</script>
</html>

上面的代码中分为ios,安卓和微信内置浏览器三种情况。实现方法均是window.location.href ="xxx://";首先尝试通过协议来唤醒手机里面的app,如果在2000ms之内跳转成功,则说明手机已经安装app,直接打开,下面定时器的代码将不会执行。如果超过2000ms之后还在这个页面,则证明用户手机没有安装app,则执行定时器里面的代码,跳到应用市场下载。

  燃鹅,当我做完这个后,老板突然说加一个这样的功能:如果你的手机已经安装过这个APP,那么上面的“打开客户端”改成“打开APP”,如果没有安装,那就会提示“下载APP”的字样。然后我眉头一皱,这个是否安装app并不是通过判断来实现的呀~~~~~它是直接尝试打开的。。。然后我作为一名职场小萌新瑟瑟发抖地回到自己的座位上开始找相关的资料,一番努力之后,果然没有~~~然后我又去问了几个已经工作了的师兄,,他们也说仅有前端是很难实现的,建议由后端判断然后返回结果给我。。。。

 

 

所以现在第二个功能还没有实现,欢迎各位小伙伴有想法的可以不吝赐教~~谢谢!

 

更多推荐

点击一个按钮,如果手机有安装app的话直接打开app,否则跳转到应用市场下载该app

本文发布于:2023-04-28 08:31:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/29e4c87fc1575acd80be84aed41478fe.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:跳转到   按钮   手机   市场   app

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!

  • 108120文章数
  • 27333阅读数
  • 0评论数