使用jQuery / plain JS检测webOS平板电脑的最佳方法是什么?
我正在寻找使用普通JS检测webOS平板电脑的最佳方法,如果使用jQuery也更容易。 平板电脑的用户代理应如下所示:
User-Agent:Mozilla/5.0 (webOS/1.3; U; en-US) AppleWebKit/532.2 (KHTML, like Gecko) Version/1.0 Safari/532.2 Desktop/1.0
所以一个简单的方法是:
var deviceAgent = navigator.userAgent.toLowerCase(); webOS = deviceAgent.match(/(webos)/);
这是最好的方法吗? 您可能会说要检测出确定存在所需的function,但这对我不起作用,因为我想要的function存在但不能像在任何桌面上那样工作,所以我真的只想知道是这是一个webOS设备与否。
更新:刚发现平板电脑确实使用了另一个用户代理:
Mozilla/5.0 (hp-tablet; Linux; hpwOS/3.0.0; U; xx-xx) AppleWebKit/534.6 (KHTML, like Gecko) wOSBrowser/233.48 Safari/534.6 TouchPad/1.0
所以上面应该是:
var deviceAgent = navigator.userAgent.toLowerCase(); webOS = deviceAgent.match(/(webos|hpwos)/);
我不知道你是否可以做任何只识别WebOS的function检测。 它是基于WebKit的,因此所有其他基于WebKit的平台都具有相同的function。 看看Zepto.js的来源,它们与你完全一样:
ua.match(/(webOS|hpwOS)[\s\/]([\d.]+)/)
(第二次捕获是版本)
来自detect.js
这是PHP中的一个function,可以检测WebOS以及您可能需要的任何其他移动设备。 代码少于1kb =)
function detectMobileDevice() { if(preg_match('/(android|avantgo|blackberry|bolt|boost|cricket|docomo|fone|hiptop|mini|mobi|palm|phone|pie|tablet|up\.browser|up\.link|webos|wos)/i', $_SERVER['HTTP_USER_AGENT'])) { return true; } else { return false; } }
如果您只想做webOS,请将第2行更改为:
if(preg_match('/(webos)/i', $_SERVER['HTTP_USER_AGENT'])) {
使用:
if(detectMobileDevice()) { // If mobile device detected, do something } else { // Otherwise, do something else... }
如果您需要更多详细信息,请访问: http : //www.justindocanto.com/scripts/detect-a-mobile-device-in-php-using-detectmobiledevice