parent_dropdown

函式
parent_dropdown ( $default_page = 0, $parent_page = 0, $level = 0, $post = null )
引數
  • (int) $default_page Optional. The default page ID to be pre-selected. Default 0.
    Required:
  • (int) $parent_page Optional. The parent page ID. Default 0.
    Required:
  • (int) $level Optional. Page depth level. Default 0.
    Required:
  • (int|WP_Post) $post Post ID or WP_Post object.
    Required:
    Default: null
返回值
  • (void|false) Void on success, false if the page has no children.
定義位置
相關方法
page_template_dropdownwp_dropdown_catswp_dropdown_userswalk_page_dropdown_treewp_dropdown_roles
引入
1.5.0
棄用
-

parent_dropdown: 這個函式在一個分層的文章型別中生成一個父文章的下拉選單。它需要三個引數。$post_type (string)表示文章型別,$parent (int)表示所選父級的ID,$args (array)表示附加引數。

列印出頁面父級下拉的選項HTML元素。

function parent_dropdown( $default_page = 0, $parent_page = 0, $level = 0, $post = null ) {
	global $wpdb;

	$post  = get_post( $post );
	$items = $wpdb->get_results(
		$wpdb->prepare(
			"SELECT ID, post_parent, post_title
			FROM $wpdb->posts
			WHERE post_parent = %d AND post_type = 'page'
			ORDER BY menu_order",
			$parent_page
		)
	);

	if ( $items ) {
		foreach ( $items as $item ) {
			// A page cannot be its own parent.
			if ( $post && $post->ID && (int) $item->ID === $post->ID ) {
				continue;
			}

			$pad      = str_repeat( ' ', $level * 3 );
			$selected = selected( $default_page, $item->ID, false );

			echo "nt<option class='level-$level' value='$item->ID' $selected>$pad " . esc_html( $item->post_title ) . '</option>';
			parent_dropdown( $default_page, $item->ID, $level + 1 );
		}
	} else {
		return false;
	}
}

常見問題

FAQs
檢視更多 >