更改Wordpress PHP以显示登录用户的不同菜单

时间:2012-08-06 23:06:24

标签: php wordpress

我在Wordpress上建立一个会员网站,并希望为登录用户显示不同的导航菜单。

以下是显示菜单的当前PHP代码:

                <?php /* Our navigation menu. */ ?>
<?php if ( isset ($options['admired_remove_superfish']) &&  ($options['admired_remove_superfish']!="") )
                    wp_nav_menu( array( 'container_class' => 'menu-header', 'theme_location' => 'primary' ) );
                else
                    wp_nav_menu( array( 'container_class' => 'menu-header', 'theme_location' => 'primary', 'menu_class' => 'sf-menu','fallback_cb' => 'admired_page_menu'  ) );?>

这里是需要替换该代码的PHP代码:

<?php
    if ( wp_emember_is_member_logged_in() ) {
    wp_nav_menu( array( 'menu' => 'logged-in-members' ) );
  } else {
    wp_nav_menu( array( 'menu' => 'normal-visitor-menu' ) );
  }
?>

如果我只是替换旧代码,使用较新的代码它将起作用,但格式化已关闭。我需要在当前代码中使用Superfish部分,但我不确定如何使它在PHP中运行。

我知道这可能有点令人困惑,但我会感激任何帮助。谢谢!

P.S。这是插件网站的教程。我一直在关注它,但我不知何故需要将Superfish留在那里。我确定不知道怎么做。

http://www.tipsandtricks-hq.com/wordpress-membership/show-different-navigation-menu-to-your-members-and-non-members-551

2 个答案:

答案 0 :(得分:3)

'menu_class' => 'sf-menu'将为菜单sf-menu class添加(<ul class="sf-menu">)super fish插件将使用此class来识别将应用的菜单和样式已在super fish插件的css

中声明
<?php
    if ( wp_emember_is_member_logged_in() ) {
        wp_nav_menu( array( 'menu' => 'logged-in-members', 'menu_class' => 'sf-menu' ) );
    } else {
        wp_nav_menu( array( 'menu' => 'normal-visitor-menu', 'menu_class' => 'sf-menu' ) );
    }
?>

了解更多see this

答案 1 :(得分:0)

考虑到上面的代码,唯一改变的是菜单的实际位置。 (现有)代码显示您需要'theme_location' => 'primary'中的菜单,因为您有一个要使用的硬编码菜单,并且您使用'menu' => 'loggged-in-members'选择它。完成的结果将是。 ..

<?php
    if ( wp_emember_is_member_logged_in() ) {
       wp_nav_menu( 
           array( 
               'container_class' => 'menu-header', 
               'menu' => 'logged-in-members', 
               'menu_class' => 'sf-menu',
               'fallback_cb' => 'admired_page_menu' 
           ) 
       );
    } else {
        wp_nav_menu( array( 'menu' => 'normal-visitor-menu' ) );
    }

&GT;