4

我的目标是建立一个基于 Wordpress 的移动网站(适用于手机和平板电脑)和响应式桌面网站。我想要最简单的方法来实现万无一失的设备检测。

移动网站将拥有许多只会真正使触摸设备受益的功能,并且将为手机和平板电脑定制设计。桌面站点将完全不同(具有相同的页面但具有额外的内容)并且将完全响应,以防万一任何设备通过检测。

我有一个可以检测触摸设备并重定向到另一个页面的衬垫,但它似乎太简单了,不能成为一种万无一失的设备检测方法。这是多么愚蠢的证明?它适用于 Windows 和 Android 设备以及 iOS 吗?

这是我第一次做这样的网站,不知道这会有多有效:

<!-- Redirect to the mobile index page if we're on a touch device -->
<script>if( 'ontouchstart' in window ) window.location = 'mobile.html';</script>
4

3 回答 3

1

对于 PHP 上的移动检测,我一直使用 $_SERVER['HTTP_USER_AGENT'] 变量。我使用下面的函数来非常精细地控制谁获得了移动网站(我想要支持的特定设备)。只需将用户代理添加到阵列(例如“Ipad”)即可添加其他设备。

function detectmobile(){
    $agent = $_SERVER['HTTP_USER_AGENT'];
    $useragents = array (
        "iPhone",
        "iPod",
        "Android",
        "blackberry9500",
        "blackberry9530",
        "blackberry9520",
        "blackberry9550",
        "blackberry9800",
        "webOS"
        );
        $result = false;
    foreach ( $useragents as $useragent ) {
    if (preg_match("/".$useragent."/i",$agent)){
            $result = true;
        }
    }
return $result;
}
if (detectmobile() == true) { wp_redirect('http://pageyouwwanttoredirectto'); }

用法:你可以将上面的代码添加到你的wordpress主题的functions.php文件中。

于 2013-02-18T16:30:19.243 回答
1

您可以使用mdetect(移动检测)库为您执行此操作。它是用多种语言编写的,可以检测 Windows、Android、iOS 等。请确保您阅读了文档。

请注意,JavaScript 版本包含此警告:

// WARNING: 
//   These JavaScript-based device detection features may ONLY work 
//   for the newest generation of smartphones, such as the iPhone, 
//   Android and Palm WebOS devices.
//   These device detection features may NOT work for older smartphones 
//   which had poor support for JavaScript, including 
//   older BlackBerry, PalmOS, and Windows Mobile devices. 
//   Additionally, because JavaScript support is extremely poor among 
//   'feature phones', these features may not work at all on such devices.
//   For better results, consider using a server-based version of this code, 
//   such as Java, APS.NET, PHP, or Ruby.
于 2013-02-18T12:22:14.717 回答
0

该代码几乎适用于任何启用触摸的设备。

于 2013-02-18T12:20:22.187 回答