zepto的detect探究
其实:
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) 相关推荐
liuxudong00 2020-11-19
章鱼之家 2020-10-29
leitingdulante 2020-10-21
xuegangic 2020-10-17
硬币0 2020-10-15
ZuoYanDeHuangHun 2020-09-18
chsoft 2020-09-17
MatrixHero 2020-08-20
XxZproject 2020-08-10
定格 2020-08-15
Mryiyi 2020-08-07
ydc0 2020-07-30
yechen00 2020-07-25
孝平 2020-07-18
ntfsformac 2020-06-23
好好学习天天 2020-06-12
Charliewolf 2020-06-05
MAC2007 2020-06-04
fanxiaoxuan 2020-06-03