wordpress后台添加子菜单 add_submenu_page()
接上文:wordpress后台添加顶级菜单 add_menu_page(),今儿再分享一下在 wordpress 后台侧边栏添加子菜单的方法,用到的函数是:add_submenu_page()
函数用法:
add_submenu_page( $parent_slug, $page_title, $menu_title, $capability, $menu_slug, $function );
下面说说各参数:
$parent_slug:(字符串) (必须)顶级菜单名称,可以在顶级菜单中加入我们的子菜单,也可以在自定义顶级菜单中加入子菜单;
Wordpress 内置菜单的几种情况:
1、在仪表盘添加子菜单: add_submenu_page( 'index.php', … ); 2、在文章处添加子菜单: add_submenu_page( 'edit.php', … ); 3、在媒体处添加子菜单: add_submenu_page( 'upload.php', … ); 4、在链接处添加子菜单: add_submenu_page( 'link-manager.php', … ); 5、在页面处添加子菜单: add_submenu_page( 'edit.php?post_type=page', … ); 6、在评论处添加子菜单: add_submenu_page( 'edit-comments.php', … ); 7、在你自定义文章类型处添加子菜单: add_submenu_page('edit.php?post_type=your_post_type',…) 8、在外观处添加子菜单: add_submenu_page( 'themes.php', … ); 9、在插件处添加子菜单: add_submenu_page( 'plugins.php', … ); 10、在用户处添加子菜单: add_submenu_page( 'users.php', … ); 11、在工具处添加子菜单: add_submenu_page( 'tools.php', … ); 12、在设置处添加子菜单: add_submenu_page( 'options-general.php', … );
$page_title:(字符串) (必须) 这个参数是子菜单的标题,将会显示在浏览器的标题栏,默认为空;
$menu_title:(字符串) (必须) 显示的菜单名称,默认为空;
$capability:(字符串) (必须) 用户权限,定义了具有哪些权限的用户会看到这个子菜单(权限部分请看文章结尾处),默认为空,参照capability;
$menu_slug:(字符串) (必须) 显示在URl上面的菜单名称,默认为空;
$function:所有调用的函数名称,通过调用这个函数来显示这个子菜单页面的内容。
俩例子,先上图:
1、在顶级菜单“工具(tools)”下添加子菜单
<?php add_action('admin_menu', 'register_my_custom_submenu_page'); function register_my_custom_submenu_page() { add_submenu_page( 'tools.php', '子菜单', '子菜单名称', 'manage_options', 'my-custom-submenu-page', 'my_custom_submenu_page_callback' ); } function my_custom_submenu_page_callback() { echo '<h3>子菜单的页面内容</h3>'; } ?>
2、在自定义的顶级菜单中添加子菜单
<?php function add_diy_menu() { add_menu_page(__('顶级菜单'),__('顶级菜单名称'),8,__FILE__,'my_function_menu'); add_submenu_page(__FILE__,'子菜单1','子菜单名称1',8,'your-admin-sub-menu1','my_function_submenu1'); add_submenu_page(__FILE__,'子菜单2','子菜单名称2',8,'your-admin-sub-menu2','my_function_submenu2'); } function my_function_menu() { echo "<h2>顶级菜单的页面内容</h2>"; } function my_function_submenu1() { echo "<h2>子菜单1的页面内容</h2>"; } function my_function_submenu2() { echo "<h2>子菜单2的页面内容</h2>"; } add_action('admin_menu','add_diy_menu'); ?>
在开发中可能会有这样的场景:一个插件自定义了顶级管理菜单和若干子菜单,同时该插件还有一些后期二次开发的独立的拓展模块,那么该如何将独立模块的管理页面添加为子菜单呢?只需要在插件创建顶级菜单的函数中,添加一个钩子hook,然后在独立的拓展模块中将submenu子菜单hook到这个钩子即可,代码如下:
// 这段代码是插件管理主菜单的创建函数 add_action('admin_menu', 'add_diy_menu'); function add_diy_menu() { add_menu_page(__('顶级菜单标题'), __('顶级菜单名称'), 'administrator', 'yjw_diy_menu', 'yjw_diy_menu_function', 'dashicons-groups'); add_submenu_page('yjw_diy_menu', __('子菜单标题01'), __('子菜单名称01'), 'administrator', 'yjw_submenu_01', 'yjw_submenu_01_function'); add_submenu_page('yjw_diy_menu', __('子菜单标题02'), __('子菜单名称02'), 'administrator', 'yjw_submenu_02', 'yjw_submenu_02_function'); // submenu hook do_action("yjw_add_diy_submenu"); } // 以下这段代码是独立模块的子菜单的创建函数,注意 yjw_diy_menu 的对应 add_action('yjw_add_diy_submenu', 'yjw_add_diy_submenu_function'); function yjw_add_diy_submenu_function(){ add_submenu_page('yjw_diy_menu', __('独立模块的子菜单标题'), __('独立模块的子菜单名称'), 'administrator', 'yjw_duli', 'yjw_duli_function'); } function yjw_duli_function(){ echo "hello"; }
另:有很多插件直接将页面菜单放在了“设置”菜单下,这里可以使用 add_options_page(),例如:
add_options_page('Yangjunwei', 'Yangjunwei', 'manage_options', 'yang', 'yang_page');
最后附上:各个用户角色所具有的权限,可以参看这个对应关系表:Capability vs. Role Table,横坐标是用户角色,纵坐标是用户权限,中间蓝色高亮部分为各个角色所拥有的权限。