判断终端是ios还是安卓的一些妙用(附加微信分享图标修改)
最近遇到一个项目 要求有两个icon(就是下载地址 下载安卓的apk 和ios的安装包)
一开始的方案是 什么设备都显示这两个icon 但是后来老大说这样不好 安卓用户给他下载ios 也不行 ios下载安卓也不行 于是就想到了一个办法 (判断终端)
于是百度了一些 经测试是可以完成的
var u = navigator.userAgent, app = navigator.appVersion;
var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1; //android终端或者uc浏览器
var isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); //ios终端
if(isAndroid){
$(".down0").css('display','none')
}else if(isiOS){
$(".down").css('display','none')
}
else{
return false;
}
判断微信:
function isWeiXin(){
var ua = window.navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i) == 'micromessenger'){
return true;
}else{
return false;
}
}
代码如下 应该都看得懂吧。。。。 这样的话什么设备就针对什么设备显示icon 完美。。。
<!DOCTYPE html>
<html> <head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<link rel="stylesheet" type="text/css" href="css/idnex.rem.css" />
<link rel="stylesheet" type="text/css" href="css/mbox.css" />
<script src="js/mbox.min.js" type="text/javascript" charset="utf-8"></script>
<title>导流页</title>
<script type="text/javascript">
var arr = {
'SM-M10': '_jku0000047',
'SM-M20': '_jku0000048',
'SM-M30': '_jku0000049',
'SM-M31': '_jku0000050',
'SM-M53': '_jku0000051',
'Sogou_Mobile-M10': '_jku0000052',
'Sogou_Mobile-M20': '_jku0000053',
'Sogou_Mobile-M30': '_jku0000054',
'Sogou_Mobile-M31': '_jku0000055',
'Sogou_Mobile-M53': '_jku0000056'
}
var version = "2.2.6"; function getUrl() {
var urls = 'https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_';
var temp = arr[GetURLlist('utm_source') + '-' + GetURLlist('utm_campaign')];
if(temp) {
var myurl = urls + version + temp + "_release.apk";
console.log(myurl);
var downs = document.getElementById('downloads').setAttribute('href', myurl);
} else {
var myurl = "https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_2.2.6_jku0000047_release.apk";
var downs = document.getElementById('downloads').setAttribute('href', myurl);
}
} function GetURLlist(name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r != null) return unescape(r[2]);
return null;
}; window.onload = function() {
getUrl();
var u = navigator.userAgent;
var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1|| u.indexOf('MI') > -1||
u.indexOf('XiaoMi') > -1; //android终端或者uc,小米等奇葩浏览器
document.getElementById('downloads').onclick = function() {
if(!isAndroid) { //是IOS点击安卓下载
$M.open({
content: '请下载iPhone版!',
conStyle: 'background-color:#404040; color:#fff; border:none;',
time: 3
});
return false; //阻止默认行为和冒泡
}
}
document.getElementById('ios').onclick = function() {
if(isAndroid) { //是安卓点击IOS下载
$M.open({
content: '请下载Android版!',
conStyle: 'background-color:#404040; color:#fff; border:none;',
time: 3
});
return false;
}
} }
</script>
</head> <body>
<div class="banner">
<img src="img/banner-0.png" />
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_012.png" />
</div>
<div class="list-right">
<p class="money">5,433,898,641</p>
<p class="tolks">累计成功放款金额</p>
</div>
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_013.png" />
</div>
<div class="list-right">
<p class="money">2,765,434</p>
<p class="tolks">累计成功放款人数</p>
</div>
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_014.png" />
</div>
<div class="list-right">
<p class="money">75%</p>
<p class="tolks">成功放款通过率</p>
</div>
</div>
<div class="list demo">
<div class="list-left">
<img src="img/icon_015.png" />
</div>
<div class="list-right">
<p class="money">无需抵押 无需面审</p>
<p class="tolks">只需手机就能完成贷款</p>
</div>
</div>
<div class="download">
<a id="downloads" class="down-lf" href="https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_2.2.6_jku0000047_release.apk">Android版下载</a>
<a id="ios" class="down-rg" href="https://itunes.apple.com/cn/app/id1138662429?mt=8">iPhone版下载</a>
</div> </body> </html>
* {
padding: 0px;
margin: 0px;
} html {
font-family: Microsoft Yahei, Avenir, Hiragino Sans GB, Microsoft Sans Serif, WenQuanYi Micro Hei, sans-serif;
font-size: 18px;
width: 100%;
height: 100%;
} body {
width: 100%;
height: 100%;
} .banner {
width: 100%;
height: auto;
} .banner img {
width: 100%;
display: block;
} .list {
height: 3.611111111111111rem;
margin-top: 1.1111111111111112rem;
border-bottom: 1px solid #efefef;
} .list-left {
margin-left: 1.7222222222222223rem;
display: block;
float: left;
} .list-left img {
width: 2.6666666666666665rem;
height: 2.6666666666666665rem;
display: block;
vertical-align: middle;
} .list-right {
height: 2.6666666666666665rem;
margin-left: 0.8333333333333334rem;
display: block;
float: left;
position: relative;
} .money {
width: 13.88888888888889rem;
position: absolute;
left: 0px;
top: -0.05555555555555555rem;
font-size: 1.3888888888888888rem;
color: #2187d0;
} .tolks {
width: 11.11111111111111rem;
position: absolute;
left: 0px;
bottom:0px;
font-size: 0.7777777777777778rem;
color: #777777;
} .demo {
border-bottom: 1px solid #efefef;
} .demo .money {
font-size: 1.1666666666666667rem;
} .demo .tolks {
margin-top: 0.1111111111111111rem;
} .download {
position: fixed;
left: 5%;
bottom: 0.8333333333333334rem;
width: 90%;
margin: 0 auto;
height: 3.3333333333333335rem;
margin-top: 2.7777777777777777rem;
margin-bottom: 0px;
} .download a {
text-decoration: none;
width: 48%;
height: 2.388888888888889rem;
background: #2187D0;
border-radius: 5px;
line-height: 2.388888888888889rem;
text-align: center;
font-size: 0.9444444444444444rem;
color: white;
} .download a.down-lf {
float: left;
} .download a.down-rg {
float: right;
} @media only screen and (max-device-width:414px) {
html {
font-size: 18px;
}
} @media only screen and (max-device-width:375px) {
html {
font-size: 17px;
}
} @media only screen and (max-device-width:320px) {
html {
font-size: 14px;
}
}
<!DOCTYPE html>
<html> <head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<link rel="stylesheet" type="text/css" href="css/idnex1.rem.css" />
<title>导流页</title>
<script type="text/javascript">
window.onload = function() {
function GetURLlist(name) {
var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
var r = window.location.search.substr(1).match(reg);
if(r != null) return unescape(r[2]);
return null;
};
function URLPlus(version, source, campaign) {
var urls = 'https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_';
this.version = version;
this.source = source;
this.campaign = campaign;
this.urlplus= function (){
if(this.source == "SM") {
switch(this.campaign) {
case "M10":return "47";break;
case "M20":return "48";break;
case "M30":return "49";break;
case "M31":return "50";break;
case "M53":return "51";break;
default:return "47";break;
}
};
if(this.source == "Sogou_Mobile") {
switch(this.campaign) {
case "M10":return "52";break;
case "M20":return "53";break;
case "M30":return "54";break;
case "M31":return "55";break;
case "M53":return "56";break;
default:return "52";break;
}
}
}
this.urlpluss=function(){
if(this.source==null){
return "https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_2.2.6_jku0000047_release.apk";
}
return urls+this.version+"_jku00000"+this.urlplus()+"_release.apk";
}
};
var source = GetURLlist('utm_source');
var campaign = GetURLlist('utm_campaign');
var myurl=new URLPlus('2.2.6', source, campaign);
var href=myurl.urlpluss();
console.log(href);
var downs=document.getElementById('downloads').setAttribute('href',href);
}
</script>
</head> <body>
<div class="banner">
<img src="img/banner-0.png" />
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_005.png" />
</div>
<div class="list-right">
<p class="money">5,433,898,641</p>
<p class="tolks">累计成功放款金额</p>
</div>
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_006.png" />
</div>
<div class="list-right">
<p class="money">2,765,434</p>
<p class="tolks">累计成功放款人数</p>
</div>
</div>
<div class="list">
<div class="list-left">
<img src="img/icon_007.png" />
</div>
<div class="list-right">
<p class="money">75%</p>
<p class="tolks">成功放款通过率</p>
</div>
</div>
<div class="list demo">
<div class="list-left">
<img src="img/icon_008.png" />
</div>
<div class="list-right">
<p class="money">无需抵押 无需面审</p>
<p class="tolks">只需手机就能完成贷款</p>
</div>
</div>
<div class="download">
<a id="downloads" class="down-lf" href="https://s3.weshare.com.cn/jiekuan2/apk/publish/haze_main_2.2.6_jku0000047_release.apk">Android版下载</a>
<a class="down-rg" href="https://itunes.apple.com/cn/app/id1138662429?mt=8">iPhone版下载</a>
</div> </body> </html>
分享图标代码:
<title>闪电借款 56秒极速到账</title>
<div id='wx_pic' style='margin:0 auto;display:none;'>
<img src='img/favicon.ico' />
</div>
判断终端是ios还是安卓的一些妙用(附加微信分享图标修改)的更多相关文章
- 判断终端是ios还是安卓的一些妙用
最近遇到一个项目 要求有两个icon(就是下载地址 下载安卓的apk 和ios的安装包) 一开始的方案是 什么设备都显示这两个icon 但是后来老大说这样不好 安卓用户给他下载ios 也不行 ...
- js,h5页面判断客户端是ios还是安卓
$(function(){ var u = navigator.userAgent, app = navigator.appVersion; var isAndroid = u.indexOf('An ...
- 判断终端是ios还是android来加载不同的样式
<script type="text/javascript"> var addStyleLink = function(href){ var head = docume ...
- JS判断终端(Android IOS)
function getMobileOperatingSystem() { var userAgent = navigator.userAgent || navigator.vendor || win ...
- 判断终端类型、微信的文章防盗链、h5页面跳转打开新的app、跳转到app市场
判断终端的类型.安卓.ios.微信.qq function GetMobelType() { var browser = { ...
- 判断当前环境是ios还是安卓
/** * @name 判断iOS */ export const isiOS = ()=>{ let u = navigator.userAgent; let iOs = !!u.match( ...
- 判断客户端是iPad、安卓还是ios
武穆逸仙 有人心疼时,眼泪才是眼泪,否则只是带着咸味的液体:被人呵护着,撒娇才是撒娇,要不然就是作死. 努力做一个可爱的人,不埋怨谁,不嘲笑谁,也不羡慕谁,阳光下灿烂,风雨中奔跑,做自己的梦,走自己的 ...
- php后台对接ios,安卓,API接口设计和实践完全攻略,涨薪必备技能
2016年12月29日13:45:27 关于接口设计要说的东西很多,可能写一个系列都可以,vsd图都得画很多张,但是由于个人时间和精力有限,所有有些东西后面再补充 说道接口设计第一反应就是r ...
- js判断Android和Ios
<!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8" ...
随机推荐
- 响应式设计:根据不同设备引不同css样式
<link rel="stylesheet" media="screen and (max-width:600px)" href="small. ...
- C# HTML 生成 PDF
原文出处:http://www.cnblogs.com/shanyou/archive/2012/09/07/2676026.html
- 深入理解JS各种this指向问题
说到this,入前端坑的人都知道这是JS初期语言毕竟之路.很多人(我就是)对于this的了解很模糊,或者不够全面.最近打算在反过来在看下es6,在es6中又出现了箭头函数对于this的理解有多了层认识 ...
- 解决CentOS7关闭/开启防火墙出现Unit iptables.service failed to load: No such file or directory.
CentOS7中执行 service iptables start/stop 会报错Failed to start iptables.service: Unit iptables.service fa ...
- 编译PHP并与Ngnix整合
nginx本身不能处理PHP,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端. nginx一般是把请求发fastcgi管理进程处理,fascgi管 ...
- ref:phpstorm配置远程调试(xdebug)(docker中)
ref:https://www.cnblogs.com/yjken/p/6555438.html readme:本文设置远程调试ubuntu中的php代码. 在docker中也可以,经过测试phpin ...
- [hdu4667]Building Fence 计算几何 瞎瘠薄搞
大致题意: 给出n个圆和m个三角形,求最小的的,能将所有图形覆盖的图形的周长. 正解为求所有三角形顶点与圆的切点以及圆和圆的切点构造凸包,再求路径. 因为要求结果误差<=1e-3 所以 我们可以 ...
- 洛谷P4139 上帝与集合的正确用法 [扩展欧拉定理]
题目传送门 上帝与集合的正确用法 题目描述 根据一些书上的记载,上帝的一次失败的创世经历是这样的: 第一天, 上帝创造了一个世界的基本元素,称做“元”. 第二天, 上帝创造了一个新的元素,称作“α”. ...
- SRPG Studio 教程(一) 创建游戏及引用素材
儿时玩红白机的时候,火纹和机器人大战这类战棋类的游戏就是博主的最爱,恰逢最近steam上上架了一款SRPG Studio用于制作火纹,趁这个机会学习一下,顺便记录下来. 秉承着一个程序猿的自我修养,以 ...
- java 接口 继承 接口 抽象类 继承 实体类
韩梦飞沙 韩亚飞 313134555@qq.com yue31313 han_meng_fei_sha 接口 可以 继承 接口 抽象类 可以 实现 接口 抽象类 继承实体类 需要 实体类 有 ...