使用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