如何在 WordPress 正文类中添加用户浏览器和操作系统类

在开发 WordPress 主题时,有时您可能需要用户的浏览器和操作系统信息来使用CSS或jQuery修改设计的某些方面。WordPress 能够为您做到这一点。在本文中,我们将向您展示如何在WordPress 正文类中添加用户的浏览器和操作系统类。

在 WordPress 中检测用户平台和浏览器

默认情况下, WordPress会为您网站的不同部分生成 CSS 类。它还提供过滤器,以便主题和插件开发人员可以挂钩自己的类。您将使用body_class过滤器将浏览器和操作系统信息添加为 CSS 类。

您需要做的第一件事是在主题的functions.php文件中添加以下代码。

function mv_browser_body_class($classes) {        global $is_lynx, $is_gecko, $is_IE, $is_opera, $is_NS4, $is_safari, $is_chrome, $is_iphone;        if($is_lynx) $classes[] = ‘lynx’;        elseif($is_gecko) $classes[] = ‘gecko’;        elseif($is_opera) $classes[] = ‘opera’;        elseif($is_NS4) $classes[] = ‘ns4’;        elseif($is_safari) $classes[] = ‘safari’;        elseif($is_chrome) $classes[] = ‘chrome’;        elseif($is_IE) {                $classes[] = ‘ie’;                if(preg_match(‘/MSIE ([0-9]+)([a-zA-Z0-9.]+)/’, $_SERVER[‘HTTP_USER_AGENT’], $browser_version))                $classes[] = ‘ie’.$browser_version[1];        } else $classes[] = ‘unknown’;        if($is_iphone) $classes[] = ‘iphone’;        if ( stristr( $_SERVER[‘HTTP_USER_AGENT’],”mac”) ) {                 $classes[] = ‘osx’;           } elseif ( stristr( $_SERVER[‘HTTP_USER_AGENT’],”linux”) ) {                 $classes[] = ‘linux’;           } elseif ( stristr( $_SERVER[‘HTTP_USER_AGENT’],”windows”) ) {                 $classes[] = ‘windows’;           }        return $classes;}add_filter(‘body_class’,’mv_browser_body_class’);

该脚本的第一部分检测用户的浏览器并将其添加到$classes. 第二部分检测用户的操作系统并将其添加到其中$classes。最后一行使用 WordPressbody_class过滤器添加类。

现在您需要将 body 类添加到主题文件中的HTML 标记中。header.php用以下代码替换模板文件中的正文行:

>

请注意,如果您正在使用像下划线这样的入门主题或像 Genesis 这样编码良好的主题框架,那么您的主题将已经在 body 标记中具有 body 类功能。实现代码后,您将能够在 HTML 源代码中看到带有 body 标记的浏览器和操作系统类。您还会注意到,WordPress 还会将其他类添加到 body 标记中。

在 WordPress 正文类中添加浏览器和操作系统信息

现在,您可以为不同的浏览器和操作系统设置类的样式,或者将它们用作 jQuery 中的选择器。我们希望本文能帮助您在 WordPress 中检测用户的浏览器和操作系统信息。

如果您刚刚开始 WordPress 主题开发,那么您可能还想看看我们为新主题设计师介绍的 Sass和WordPress Body Class 101 。如果您有任何反馈或问题,请在下方发表评论,让我们知道。

资料来源:贾斯汀·斯腾伯格