wordpress后台添加子菜单 add_submenu_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] | wordpress后台添加子菜单 add_submenu_page() | 讯沃blog

1、在顶级菜单“工具(tools)”下添加子菜单

子菜单的页面内容';
}
?>

2、在自定义的顶级菜单中添加子菜单

顶级菜单的页面内容";
}
function my_function_submenu1() {
    echo "

子菜单1的页面内容

"; } function my_function_submenu2() { echo "

子菜单2的页面内容

"; } 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,横坐标是用户角色,纵坐标是用户权限,中间蓝色高亮部分为各个角色所拥有的权限。

© 版权声明
THE END
喜欢就支持一下吧
点赞0赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容