Description
The Post Object field creates an interactive dropdown to select one or more posts, pages, or custom post type items. This field type uses the Select2 library to enable search and AJAX functionality.
Screenshots
Settings
Filter by Post Type
Filters the selectable results by post type. When left empty, all post types are shown. Results are grouped by post type, so selected post types may be positioned in a specific order.Filter by Post Status
Filters the selectable results by status of the post, i.e, Published, Draft, etc. Shows posts of every status if left empty.Filter by Taxonomy
Filters the selectable results via one or more taxonomy terms.Return Format Specifies the returned value format. Choose from Post Object (
WP_Post
) or Post ID (integer).Select Multiple Allows content editors to select more than one choice and reorder the selected choices by dragging and dropping. Defaults to off.
Required
Found on the Validation tab, this requires an input be entered, preventing the field from accepting empty values. Defaults to off.Allow Null
When enabled, this allows the current selection to be cleared and an empty value to be saved. Defaults to off.Instructions
Shows instructions when submitting data.Conditional Logic
Enabling this setting allows you to customize the logic which determines if the current field should be visible. Groups of conditional logic rules can be created to allow for multiple and/or statements.Bidirectional
Found on the Advanced tab, enabling this setting allows you to update a value in the target fields for each value selected for this field, adding or removing the Post ID, Taxonomy ID, or User ID of the item being updated. Please see Bidirectional Relationships for more information on using this setting to create bidirectional relationships directly in ACF’s UI.
Template usage
Depending on the chosen field settings, the Post Object field will return either a single value, or an array where each value is a WP_Post
object or an integer.
Display selected post
This example demonstrates how to display basic data (such as the post_title) from a Post Object value. The field in this example uses Post Object as the Return Format and is a single value.
<?php
$featured_post = get_field('featured_post');
if( $featured_post ): ?>
<h3><?php echo esc_html( $featured_post->post_title ); ?></h3>
<?php endif; ?>
Display list of posts (with setup_postdata)
This example demonstrates how to loop over a Post Object value and display a list of clickable links. Here, we use a special function named setup_postdata()
to enable the use of WordPress template functions. The field in this example uses Post Object as the Return Format and is a multiple value.
<?php
$featured_posts = get_field('featured_posts');
if( $featured_posts ): ?>
<ul>
<?php foreach( $featured_posts as $post ):
// Setup this post for WP functions (variable must be named $post).
setup_postdata($post); ?>
<li>
<a href="<?php the_permalink(); ?>"><?php the_title(); ?></a>
<span>A custom field from this post: <?php the_field( 'field_name' ); ?></span>
</li>
<?php endforeach; ?>
</ul>
<?php
// Reset the global post object so that the rest of the page works correctly.
wp_reset_postdata(); ?>
<?php endif; ?>
Display list of posts (without setup_postdata)
This example demonstrates how to loop over a Post Object value and display a list of clickable links. Here, the global post variable is never changed, so all “post” related functions need a second parameter to specify which object. The field in this example uses Post Object as the Return Format and is a multiple value.
<?php
$featured_posts = get_field('featured_posts');
if( $featured_posts ): ?>
<ul>
<?php foreach( $featured_posts as $featured_post ):
$permalink = get_permalink( $featured_post->ID );
$title = get_the_title( $featured_post->ID );
$custom_field = get_field( 'field_name', $featured_post->ID );
?>
<li>
<a href="<?php echo esc_url( $permalink ); ?>"><?php echo esc_html( $title ); ?></a>
<span>A custom field from this post: <?php echo esc_html( $custom_field ); ?></span>
</li>
<?php endforeach; ?>
</ul>
<?php endif; ?>
Notes
Customization
The Post Object field contains PHP filters to customize the posts displayed, and the text displayed for each post.
Supercharge Your Website With Premium Features Using ACF PRO
Speed up your workflow and unlock features to better develop websites using ACF Blocks and Options Pages, with the Flexible Content, Repeater, Clone, Gallery Fields & More.
Related
- Field Types: Relationship
- Field Types: User
- Choice: Select
- Field Types: Taxonomy
- Field Types: Page Link