get_ancestors()WP 3.1.0

Get an array of ancestor IDs for a given object.

1 time — 0.00174 sec (very slow) | 50000 times — 0.95 sec (very fast) | PHP 7.2.5, WP 5.0.1
Hooks from the function

Return

Int[]. An array of IDs of ancestors from lowest to highest in the hierarchy.

Usage

get_ancestors( $object_id, $object_type, $resource_type );
$object_id(int)
The ID of the object.
$object_type(string)
The type of object for which we'll be retrieving ancestors. Accepts a post type or a taxonomy name.
Default: ''
$resource_type(string)
Type of resource $object_type is. Accepts 'post_type' or 'taxonomy'.
Default: ''

Examples

0

#1 Get the IDs of all parent elements of the taxonomy term

Suppose we have this category structure. The IDs are in brackets:

  • Books (6)
    • fiction (23)
      • Ray Bradbury (208)
$ancestors = get_ancestors( 208, 'category' );

Now, the variable $ancestors will contain such an array:

Array
(
	[0] => 23
	[1] => 6
)
0

#2 Get the IDs of all parent pages

Suppose, you need to get the IDs of the parent static pages, let's assume we have this structure:

  • About site (447)
    • Subsidiary page (448)
$ancestors = get_ancestors( 448, 'page' );

Now, the variable $ancestors will contain an array:

Array
(
	[0] => 447
)
0

#3 Get the ID of the topmost parent category

$ancestors = get_ancestors( 208, 'category' );
$top_cat_id = array_pop( $ancestors );

Changelog

Since 3.1.0 Introduced.
Since 4.1.0 Introduced the $resource_type argument.

get_ancestors() code WP 6.5.2

function get_ancestors( $object_id = 0, $object_type = '', $resource_type = '' ) {
	$object_id = (int) $object_id;

	$ancestors = array();

	if ( empty( $object_id ) ) {

		/** This filter is documented in wp-includes/taxonomy.php */
		return apply_filters( 'get_ancestors', $ancestors, $object_id, $object_type, $resource_type );
	}

	if ( ! $resource_type ) {
		if ( is_taxonomy_hierarchical( $object_type ) ) {
			$resource_type = 'taxonomy';
		} elseif ( post_type_exists( $object_type ) ) {
			$resource_type = 'post_type';
		}
	}

	if ( 'taxonomy' === $resource_type ) {
		$term = get_term( $object_id, $object_type );
		while ( ! is_wp_error( $term ) && ! empty( $term->parent ) && ! in_array( $term->parent, $ancestors, true ) ) {
			$ancestors[] = (int) $term->parent;
			$term        = get_term( $term->parent, $object_type );
		}
	} elseif ( 'post_type' === $resource_type ) {
		$ancestors = get_post_ancestors( $object_id );
	}

	/**
	 * Filters a given object's ancestors.
	 *
	 * @since 3.1.0
	 * @since 4.1.1 Introduced the `$resource_type` parameter.
	 *
	 * @param int[]  $ancestors     An array of IDs of object ancestors.
	 * @param int    $object_id     Object ID.
	 * @param string $object_type   Type of object.
	 * @param string $resource_type Type of resource $object_type is.
	 */
	return apply_filters( 'get_ancestors', $ancestors, $object_id, $object_type, $resource_type );
}