HI,欢迎来到我爱模板网!

WordPress实现登陆用户和未登陆用户显示不同菜单

大多数WordPress主题都支持在后台 – 外观 – 菜单中设置网站的菜单,而且可以创建多个菜单,给各个菜单单独设置菜单项。 WordPress 目前有这样的需求:网站头部有一个导航菜单,想在这个位置给登录和未登录用户分别显示不同的菜单项,该如何实现呢?WordPress给我们提供了wp_nav_menu_args这...

大多数WordPress主题都支持在后台 – 外观 – 菜单中设置网站的菜单,而且可以创建多个菜单,给各个菜单单独设置菜单项。

WordPress实现登陆用户和未登陆用户显示不同菜单
WordPress

目前有这样的需求:网站头部有一个导航菜单,想在这个位置给登录和未登录用户分别显示不同的菜单项,该如何实现呢?WordPress给我们提供了wp_nav_menu_args这个filter,可以在菜单显示之前更改wp_nav_menu函数的参数。具体我们可以这样实现:

1、创建两个菜单

先进入WordPress后台 – 外观 – 菜单中, 创建两个菜单,菜单名称分别设置成:已登录 和 未登录,并给这两个菜单分配不同的菜单项。

2、确定菜单位置名称

开始下一步前,我们需要知道菜单位置名称,也就是theme_location参数的值,用文本编辑器打开当前主题目录中的header.php,搜索wp_nav_menu一般都能找到这个值,代码一般长这样:

// theme_location后面的 top 就是我们要找的值
wp_nav_menu( array( 'theme_location' => 'top', 'menu_id' => 'top-menu') );

如果你实在不懂代码,具体可以看视频教程提供的简便方法:确定菜单位置名称

3、添加执行代码

最后,在当前主题的functions.php添加以下代码即可:

function ludou_nav_menu_args($args = '') {
// 下面的top改成第2步获取到的菜单位置名称
if ($args['theme_location'] == 'top') {
if (is_user_logged_in()) {
$args['menu'] = '已登录';
}
else {
$args['menu'] = '未登录';
}
}

return $args;
}

add_filter('wp_nav_menu_args', 'ludou_nav_menu_args');

给TA打赏
共{{data.count}}人
人已打赏
wordpress教程

WordPress主题remove_action在子主题中不起作用解决方法

2023-1-1 7:43:32

wordpress教程

企业租赁阿里云高性能云服务器优惠攻略

2023-1-1 7:43:34

【腾讯云】11.11云上盛惠!云服务器首年1.8折起,买1年送3个月!
11.11云上盛惠!海量产品·轻松上云!云服务器首年1.8折起,买1年送3个月!超值优惠,性能稳定,让您的云端之旅更加畅享。
查看更多相关信息>>
站长

(工作日 10:00 - 22:30 为您服务)

2026-01-30 14:41:37

您好,无论是售前、售后、意见建议……均可通过联系工单与我们取得联系。

猜你想问:

  • 购买的模板免费包安装吗?

  • 这个演示地址有吗?

  • 购买vip会员可以下载哪些模板?

您的留言我们已经收到,我们将会尽快跟您联系!
取消
立即选择任一渠道联系我们