二维码跳转不同的 app store
说道二维码 之前是用来跳转app store 然后在就是出来的 扫码付款什么的
用的很平常,其实里面也很简单 自己刚开始接触的时候 同事说要做一个二维码下载 应用 => 我=懵逼
会看到大家把android 和ios 的二维码并排放在一起 我们的产品ios先出来的 就先放了一个二维码 (毕竟可以二合一呗)
什么鬼 二维码是个什么 ?
还要根据不同的平台 ?
还要取是什么浏览器打开的这个 ?
还要判断是不是wechat? 我的天 !!!!
作为刚出校门的小菜鸟 不懂就得问啊 在学校里那都是 舅舅不疼 姥姥不爱的 关于这技术 以前暑假的时候晓得一点
NO :1
就是那其实二维码 就是一个 URL 地址
说道平台 大家一定会想到 什么 mac地址什么的 但是好像浏览器也屏蔽掉了
这可咋办呢 ?
还是自己看着经理去抽烟的时候 这不 菜鸟不知道怎么办 只能以拉家常的方式去和经理说说技术
me : 老大 ,那做二维码跳转 怎么知道他是什么平台的呢 ? 怎么获取到机型呢?
老大: 这个很简单的 你根据浏览器的报头去做就好了,其实扫描到了二维码之后 读取到了 手机会调用浏览器去访问该网址 ,
ios的则会调用 safair android的则会调用chrome 虽然还有什么uc ,opera 难免的会有些误差。 你自己琢磨吧!
me : 那好吧 !
找找查查 就是 navigator.userAgent navigator.appVersion
接着就是考虑在后台处理还是在前台
算了 还是前台判断吧
var browser = {
versions: function () {
var u = navigator.userAgent, app = navigator.appVersion;
return {
//移动终端浏览器版本信息
trident: u.indexOf('Trident') > -1, //IE内核
presto: u.indexOf('Presto') > -1, //opera内核
webKit: u.indexOf('AppleWebKit') > -1,//苹果、谷歌内核
safari:u.indexOf("Safari")>-1, //safari 浏览器
gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
mobile: !!u.match(/AppleWebKit.*Mobile.*/) || !!u.match(/AppleWebKit/), //是否为移动终端
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或者uc浏览器
iPhone: u.indexOf('iPhone') > -1 || u.indexOf('Mac') > -1, //是否为iPhone或者QQHD浏览器
iPad: u.indexOf('iPad') > -1, //是否iPad
wechat:u.toLowerCase().match((/MicroMessenger/i) == 'micromessenger'),
webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部
};
}(),
language: (navigator.browserLanguage || navigator.language).toLowerCase()
}
var explore;
if (browser.versions.trident)
{
explore = 'IE';
} else if (browser.versions.presto)
{
explore = 'Opera';
} else if (browser.versions.webKit) {
explore = 'chrome';
} else if (browser.versions.gecko)
{
explore = 'FireFox';
} else if (browser.versions.safari)
{
explore = 'safarir';
}
if (browser.versions.ios || browser.versions.iPhone || browser.versions.iPad) {
alert('ios手机');
$.ajax({
url: "DataInsert.ashx?Explore=" + explore + "&device=ios&deviceappVersion=" + navigator.appVersion,
type: "post",
success: function (data)
{
if (data == "success")
{
location.href = "http://www.apple.com/cn/ios/";
}
}, error: function (errorMsg) {
//请求失败时执行该函数
alert("数据异常");
}
});
}
else if (browser.versions.android) {
alert('安卓手机');
$.ajax({
url: "DataInsert.ashx?Explore=" + explore + "&device=Android&deviceappVersion=" + navigator.appVersion,
type: "post",
success: function (data) {
if (data == "success") {
location.href = "http://www.android-studio.org/"; //这里就给了一个学习网站 哈哈
}
}, error: function (errorMsg) {
//请求失败时执行该函数
alert("数据异常");
}
});
} else if (browser.versions.wechat)
{
$.ajax({
url: "DataInsert.ashx?Explore=" + explore + "&device=wechat&deviceappVersion=" + navigator.appVersion,
type: "post",
success: function (data) {
if (data == "success") {
location.href = "http://weixin.qq.com/";
}
}, error: function (errorMsg) {
//请求失败时执行该函数
alert("数据异常");
}
});
alert('微信');
}
这都获取的很详细了吧
在异步里去拼接 判断什么 浏览器 什么机型 wechat 什么的 都是妥妥的了 。
二维码跳转不同的 app store的更多相关文章
- 微信小程序 - 配置普通二维码跳小程序
普通二维码跳小程序规则: https://developers.weixin.qq.com/miniprogram/introduction/qrcode.html#%E5%8A%9F%E8%83%B ...
- asp:手机扫描二维码跳转手机版
如果想手机扫描用pc版网站生成的二维码跳转到对应的手机版的话,请在pc端的首页的<head></head>标签里面加入下面内容: <script src=" ...
- PHP自定义生成二维码跳转地址
比较简单的一款PHP自定义生成二维码跳转地址,手机端微信扫码,自动跳转到定义好的链接.支持自定义生成二维码尺寸.间距等. 鼠标悬浮显示二维码弹出层,离开后消失.js实现,代码如下: $(fu ...
- 用vue实现扫描二维码跳转页面功能
怎么能用vue实现扫描二维码跳转页面功能 1. 安装依赖 npm install vue-qr --save 2. <template> <div> <div ...
- 今天网站后台登录页面需要生成一个二维码,然后在手机app上扫描这个二维码,实现网站登录的效果及其解决方案如下
要实现二维码登录,需要解决2个技术,1.需要js websocket 与后台php实现长连接技术 2.实现二维码生成技术 要实现这个功能第二个算是比较简单,只需要下载一个php的二维码生成器即可,但要 ...
- 扫描二维码下载安装apk的app
将apk文件放到服务器上,下载链接直接生成二维码,用微信扫描时不能直接下载.页面只是刷新一下. 想实现微信扫描下载apk的app客户端,需要把下载链接做到一个网页上, 将网页生成一个二维码. 直接下载 ...
- 微信小程序二维码是无法识别二维码跳转到小程序
今天测试了一下,微信小程序圆形二维码是不能直接识别跳转到小程序: 但h5页面的那种微信公众号二维码是可以直接识别
- php生成带自定义logo和带二维码跳转自定义地址的二维码
index.php<?phpheader('Content-type:text/html;charset=UTF-8');// 指定允许其他域名访问header('Access-Control- ...
- 扫描二维码跳转app
1.判断是否安装了app <html> <head> <meta name="viewport" content="width=device ...
随机推荐
- Java防止SQL注入(转)
一.SQL注入简介 SQL注入是比较常见的网络攻击方式之一,它不是利用操作系统的BUG来实现攻击,而是针对程序员编程时的疏忽,通过SQL语句,实现无帐号登录,甚至篡改数据库. 二.SQL注入攻击的总体 ...
- log4j分离日志输出 自定义过滤 自定义日志文件
普通的log4j.properties 定义: ### set log levels ### log4j.rootLogger = debug,D,E ## Disable other log log ...
- History lives on in this distinguished Polish city II 2017/1/5
原文 Some fresh air After your time underground,you can return to ground level or maybe even a little ...
- [DUBBO]Dubbo控制台查看方法
1.dubbo控制台安装方法网上较多,例如转载http://dtbuluo.com/blog/archives/37 2.dubbo控制台查看 由于我们组是开发安装的dubbo.zookeeper等等 ...
- iOS之UIKit系列教程<一>
前言:博主接触iOS的编程也有一段时间,今天把有关UI控件的一些知识在这里做一些总结. 申明:此系列文章都是使用目前最新版本swift3.0.1进行讲解的,与其他版本可能略有差异. 一,UIKit之设 ...
- C# Struct结构体里数组长度的指定
typedef struct Point{ unsigned short x; unsigned short y; }mPoint;//点坐标 typedef struct Line{ mPoint ...
- React 组件性能优化探索实践
转自:http://www.tuicool.com/articles/Ar6Zruq React本身就非常关注性能,其提供的虚拟DOM搭配上Diff算法,实现对DOM操作最小粒度的改变也是非常的高效. ...
- AVL树
AVL树 在二叉查找树(BST)中,频繁的插入操作可能会让树的性能发生退化,因此,需要加入一些平衡操作,使树的高度达到理想的O(logn),这就是AVL树出现的背景.注意,AVL树的起名来源于两个发明 ...
- 百度编辑器ueditor插入表格没有边框颜色的解决方法
附:从word excel 中 复制的表格提交后无边框,参考这个同学的,写的很详细: http://blog.csdn.net/lovelyelfpop/article/details/51678 ...
- .htaccess基本语法和应用 (2012-11-09 16:13:47)转载▼
htaccess基本语法和应用 (2012-11-09 16:13:47) 转载▼ 标签: htaccess it 分类: 网络 .htaccess是Apache服务器的一个非常强大的分布式配置文件 ...