icewizardry 2013-03-11
其实:
zepto有自身的函数接口去判断设备和浏览器
我拿iOS模拟器跑测试:
//Zepto.os 查看设备
Zepto.os返回一个对象:
{
ios:true,
iphone:true,
version:"6.1"
}
//Zepto.browser 查看浏览器
Zepto.browser返回一个对象:
{
version:"536.26"
webkit:true
}
源码来自:detect.js
;(function($){
//创建一个detect函数,参数为ua
function detect(ua){
//this为Zepto,给它绑两个属性:一个os,一个browser
var os = this.os = {},
browser = this.browser = {},
webkit = ua.match(/WebKit\/([\d.]+)/),
android = ua.match(/(Android)\s+([\d.]+)/),
ipad = ua.match(/(iPad).*OS\s([\d_]+)/),
iphone = !ipad && ua.match(/(iPhone\sOS)\s([\d_]+)/),
webos = ua.match(/(webOS|hpwOS)[\s\/]([\d.]+)/),
touchpad = webos && ua.match(/TouchPad/),
kindle = ua.match(/Kindle\/([\d.]+)/),
silk = ua.match(/Silk\/([\d._]+)/),
blackberry = ua.match(/(BlackBerry).*Version\/([\d.]+)/),
bb10 = ua.match(/(BB10).*Version\/([\d.]+)/),
rimtabletos = ua.match(/(RIM\sTablet\sOS)\s([\d.]+)/),
playbook = ua.match(/PlayBook/),
chrome = ua.match(/Chrome\/([\d.]+)/) || ua.match(/CriOS\/([\d.]+)/),
//比如火狐19,这边firefox是一个数组:["Firefox/19.0","19.0"];
firefox = ua.match(/Firefox\/([\d.]+)/)
// Todo: clean this up with a better OS/browser seperation:
// - discern (more) between multiple browsers on android
// - decide if kindle fire in silk mode is android or not
// - Firefox on Android doesn't specify the Android version
// - possibly devide in os, device and browser hashes
if (browser.webkit = !!webkit) browser.version = webkit[1]
if (android) os.android = true, os.version = android[2]
if (iphone) os.ios = os.iphone = true, os.version = iphone[2].replace(/_/g, '.')
if (ipad) os.ios = os.ipad = true, os.version = ipad[2].replace(/_/g, '.')
if (webos) os.webos = true, os.version = webos[2]
if (touchpad) os.touchpad = true
if (blackberry) os.blackberry = true, os.version = blackberry[2]
if (bb10) os.bb10 = true, os.version = bb10[2]
if (rimtabletos) os.rimtabletos = true, os.version = rimtabletos[2]
if (playbook) browser.playbook = true
if (kindle) os.kindle = true, os.version = kindle[1]
if (silk) browser.silk = true, browser.version = silk[1]
if (!silk && os.android && ua.match(/Kindle Fire/)) browser.silk = true
//如果chrome有值的话,给browser装两个属性firefix和version
if (chrome) browser.chrome = true, browser.version = chrome[1]
//如果firefox有值的话,给browser装两个属性firefix和version
if (firefox) browser.firefox = true, browser.version = firefox[1]
//os必有一个属性tablet来标示是否是平板
os.tablet = !!(ipad || playbook || (android && !ua.match(/Mobile/)) || (firefox && ua.match(/Tablet/)))
//os必有一个属性phone来标示是否是手机,但是有问题:如果是pc的火狐,返回的居然也是true(当然它本身针对移动端的,呵呵,忽略忽略)
os.phone = !!(!os.tablet && (android || iphone || webos || blackberry || bb10 || chrome || firefox))
}
//调用detect方法,把navigator.userAgent当参数传入
detect.call($, navigator.userAgent);
// make available to unit tests
//给Zepto绑上一个key为__detect对应的是detect这个function
$.__detect = detect
})(Zepto)