wordpress菜单中的自定义活动菜单项

时间:2012-07-04 12:44:39

标签: php wordpress

我有一个wordpress主题使用wp_nav_menu()来构建菜单。我在这个菜单中有一个自定义菜单项,转到非标准的wordpress页面。有没有办法可以根据网址字符串中的匹配条件将此导航项有条件地设置为当前?

由于

1 个答案:

答案 0 :(得分:4)

您可以使用Wordpress中的nav_menu_css_class来获得您所追求的结果。使用此钩子,您可以更改可应用于菜单的CSS类数组。

add_filter( 'nav_menu_css_class', 'add_parent_url_menu_class', 10, 2 );

function add_parent_url_menu_class( $classes = array(), $item = false ) {
    // Get current URL
    $current_url = current_url();
    // Get homepage URL
    $homepage_url = trailingslashit( get_bloginfo( 'url' ) );
    // Exclude 404 and homepage
    if( is_404() or $item->url == $homepage_url ) return $classes;
        if ( strstr( $current_url, $item->url) ) {
            // Add the 'parent_url' class
            $classes[] = 'parent_url';
        }
    return $classes;
}

function current_url() {
    // Protocol
    $url = ( 'on' == $_SERVER['HTTPS'] ) ? 'https://' : 'http://';
    $url .= $_SERVER['SERVER_NAME'];
    // Port
    $url .= ( '80' == $_SERVER['SERVER_PORT'] ) ? '' : ':' . $_SERVER['SERVER_PORT'];
    $url .= $_SERVER['REQUEST_URI'];

    return trailingslashit( $url );
}

此方法将忽略404页面或站点的根目录,但如果当前URL与菜单项URL匹配,则会将该类添加到菜单项。

此代码完全归功于:http://www.rarescosma.com/2010/11/add-a-class-to-wp_nav_menu-items-with-urls-included-in-the-current-url/