wp_dropdown_pages()
云策文档标注
概述
wp_dropdown_pages() 函数用于检索或显示页面列表作为下拉选择框(select 列表)。它基于 get_pages() 函数构建,支持丰富的参数配置,适用于 WordPress 开发中的页面选择场景。
关键要点
- 函数返回或输出 HTML 下拉列表,可通过 echo 参数控制输出方式。
- 参数包括深度控制、子页面筛选、选中项设置、HTML 属性(如 name、id、class)等。
- 支持从 get_pages() 继承的参数,如排序、层级、排除/包含页面、元数据过滤等。
- 提供 show_option_none 和 show_option_no_change 选项,用于自定义无页面或“无变化”时的显示文本。
- 使用 wp_dropdown_pages 过滤器可自定义 HTML 输出。
代码示例
// 基本用法:显示页面下拉列表
wp_dropdown_pages( array(
'name' => 'page_id',
'selected' => 5,
'echo' => 1
) );
// 高级用法:结合 get_pages() 参数
$dropdown_args = array(
'post_type' => 'page',
'sort_column' => 'menu_order, post_title',
'show_option_none' => '选择页面',
'echo' => 0
);
$pages = wp_dropdown_pages( $dropdown_args );注意事项
- 对于自定义文章类型,需在 register_post_type 时设置 'hierarchical' => true 以使下拉列表正常工作。
- 参数 $value_field 控制选项的 value 属性,默认为 'ID',可更改为其他文章字段。
- 使用过滤器 wp_dropdown_pages 可修改输出,例如实现多选功能。
原文内容
Retrieves or displays a list of pages as a dropdown (select list).
Description
See also
Parameters
$argsarray|stringoptional-
Array or string of arguments to generate a page dropdown. See get_pages() for additional arguments.
depthintMaximum depth. Default 0.child_ofintPage ID to retrieve child pages of. Default 0.selectedint|stringValue of the option that should be selected. Default 0.echobool|intWhether to echo or return the generated markup. Accepts 0, 1, or their bool equivalents. Default 1.namestringValue for the'name'attribute of the select element.
Default'page_id'.idstringValue for the'id'attribute of the select element.classstringValue for the'class'attribute of the select element. Default: none.
Defaults to the value of$name.show_option_nonestringText to display for showing no pages. Default empty (does not display).show_option_no_changestringText to display for “no change” option. Default empty (does not display).option_none_valuestringValue to use when no page is selected. Default empty.value_fieldstringPost field used to populate the'value'attribute of the option elements. Accepts any valid post field. Default'ID'.
More Arguments from get_pages( … $args )
Array or string of arguments to retrieve pages.
child_ofintPage ID to return child and grandchild pages of. Note: The value of$hierarchicalhas no bearing on whether$child_ofreturns hierarchical results. Default 0, or no restriction.sort_orderstringHow to sort retrieved pages. Accepts'ASC','DESC'. Default'ASC'.sort_columnstringWhat columns to sort pages by, comma-separated. Accepts'post_author','post_date','post_title','post_name','post_modified','menu_order','post_modified_gmt','post_parent','ID','rand','comment*count'.
'post*'can be omitted for any values that start with it.
Default'post_title'.hierarchicalboolWhether to return pages hierarchically. If false in conjunction with$child_ofalso being false, both arguments will be disregarded.
Default true.excludeint[]Array of page IDs to exclude.includeint[]Array of page IDs to include. Cannot be used with$child_of,$parent,$exclude,$meta_key,$meta_value, or$hierarchical.meta_keystringOnly include pages with this meta key.meta_valuestringOnly include pages with this meta value. Requires$meta_key.authorsstringA comma-separated list of author IDs.parentintPage ID to return direct children of. Default -1, or no restriction.exclude_treestring|int[]Comma-separated string or array of page IDs to exclude.numberintThe number of pages to return. Default 0, or all pages.offsetintThe number of pages to skip before returning. Requires$number.
Default 0.post_typestringThe post type to query. Default'page'.post_statusstring|arrayA comma-separated list or array of post statuses to include.
Default'publish'.
Source
function wp_dropdown_pages( $args = '' ) {
$defaults = array(
'depth' => 0,
'child_of' => 0,
'selected' => 0,
'echo' => 1,
'name' => 'page_id',
'id' => '',
'class' => '',
'show_option_none' => '',
'show_option_no_change' => '',
'option_none_value' => '',
'value_field' => 'ID',
);
$parsed_args = wp_parse_args( $args, $defaults );
$pages = get_pages( $parsed_args );
$output = '';
// Back-compat with old system where both id and name were based on $name argument.
if ( empty( $parsed_args['id'] ) ) {
$parsed_args['id'] = $parsed_args['name'];
}
if ( ! empty( $pages ) ) {
$class = '';
if ( ! empty( $parsed_args['class'] ) ) {
$class = " class='" . esc_attr( $parsed_args['class'] ) . "'";
}
$output = "<select name='" . esc_attr( $parsed_args['name'] ) . "'" . $class . " id='" . esc_attr( $parsed_args['id'] ) . "'>n";
if ( $parsed_args['show_option_no_change'] ) {
$output .= "t<option value="-1">" . $parsed_args['show_option_no_change'] . "</option>n";
}
if ( $parsed_args['show_option_none'] ) {
$output .= "t<option value="" . esc_attr( $parsed_args['option_none_value'] ) . '">' . $parsed_args['show_option_none'] . "</option>n";
}
$output .= walk_page_dropdown_tree( $pages, $parsed_args['depth'], $parsed_args );
$output .= "</select>n";
}
/**
* Filters the HTML output of a list of pages as a dropdown.
*
* @since 2.1.0
* @since 4.4.0 `$parsed_args` and `$pages` added as arguments.
*
* @param string $output HTML output for dropdown list of pages.
* @param array $parsed_args The parsed arguments array. See wp_dropdown_pages()
* for information on accepted arguments.
* @param WP_Post[] $pages Array of the page objects.
*/
$html = apply_filters( 'wp_dropdown_pages', $output, $parsed_args, $pages );
if ( $parsed_args['echo'] ) {
echo $html;
}
return $html;
}
Hooks
- apply_filters( ‘wp_dropdown_pages’, string $output, array $parsed_args, WP_Post[] $pages )
-
Filters the HTML output of a list of pages as a dropdown.
Skip to note 5 content
John Dorner
For this to work for custom post types, you must set
'hierarchical' => truein the custom post type’s settings when you register_post_type that you are getting the dropdown for.
If you don’t want the custom post type to truly be hierarchical, ensure the
'supports'arg doesn’t include'page-attributes'Skip to note 6 content
Codex
Dropdown with submit button
Displays a hierarchical page dropdown list in HTML form with a submit button.
<li id="pages"> <h2></h2> <form action="<?php bloginfo('url'); ?>" method="get"> <input type="submit" name="submit" value="view" /> </form> </li>Skip to note 7 content
Sachyya
Make dropdown list multiple select
This is useful when you want to make multiple select or using with
select2.jskinda things.add_filter( 'wp_dropdown_pages', 'wporg_domain_make_multiple_select_pages' ); function wporg_domain_make_multiple_select_pages( $output ) { return str_replace( '<select ', '<select multiple="multiple" ', $output ); }Skip to note 8 content
jon
In addition, $args can include ‘sort_column’ and other get_pages() parameters, as shown in the page_attributes_meta_box() source code:
$dropdown_args = array( 'post_type' => $post->post_type, 'exclude_tree' => $post->ID, 'selected' => $post->post_parent, 'name' => 'parent_id', 'show_option_none' => __('(no parent)'), 'sort_column' => 'menu_order, post_title', 'echo' => 0, ); ... $pages = wp_dropdown_pages( $dropdown_args );