Outil de recherche WordPress pour les développeurs et auteurs de thèmes



get_page_hierarchy ›

Depuis2.0.0
Dépréciéen/a
get_page_hierarchy ( $pages, $page_id = 0 )
Paramètres: (2)
  • (array) $pages Posts array (passed by reference).
    Requis: Oui
  • (int) $page_id Optional. Parent page ID. Default 0.
    Requis: Non
    Défaut:
Retourne:
  • (array) A list arranged by hierarchy. Children immediately follow their parents.
Défini(e) dans:
Codex:

Order the pages with children under parents in a flat list.

It uses auxiliary structure to hold parent-children relationships and runs in O(N) complexity



Source

function get_page_hierarchy( &$pages, $page_id = 0 ) {
	if ( empty( $pages ) ) {
		return array();
	}

	$children = array();
	foreach ( (array) $pages as $p ) {
		$parent_id                = intval( $p->post_parent );
		$children[ $parent_id ][] = $p;
	}

	$result = array();
	_page_traverse_name( $page_id, $children, $result );

	return $result;
}