The upcoming version of Oxygen, v3 is going to include a visual loop builder using which we can loop through the rows of a repeater-type custom field created via ACF and configure the output visually.
Until then, we will have to do it manually.
This tutorial provides the steps to display rows of
data:image/s3,"s3://crabby-images/9dd3d/9dd3d2de976e2c9e2652eb59306f1ec9c9f2d481" alt=""
Scenario:
Custom Post Type: dogfood
ACF Field group name: Dog Food Ingredients
Field name: ingredients
Sub field name: ingredient
data:image/s3,"s3://crabby-images/8f0e0/8f0e0d0ede66f230c675381429e65396cdfccb2c" alt=""
With a list of ingredients entered for a Dog Food entry,
data:image/s3,"s3://crabby-images/3f6b6/3f6b677b03eaddbd2cf632144c65e3e64e68edee" alt=""
the objective is to show these on the front end as a simple unordered list:
data:image/s3,"s3://crabby-images/82770/82770869127807a675d70adf06f59c3c2a0d7964" alt=""
Step 1
Edit the Template that applies to all single entries of dogfood
CPT with Oxygen.
Add a Section.
Add a Heading inside that reads say, “Ingredients”.
Add a Code Block.
PHP & HTML:
<?php
// check if the repeater field has rows of data
if ( have_rows( 'ingredients' ) ) {
echo '<ul class="ingredients">';
// loop through the rows of data
while ( have_rows( 'ingredients' ) ) : the_row();
printf( '<li class="ingredient">%s</li>', get_sub_field( 'ingredient' ) );
endwhile;
echo '</ul>';
} else {
// no rows found
}
?>
Step 2
If every Dog Food entry is to have at least one ingredient entered, ingredients
Let’s make it such that the Section is only output if at least 1 ingredient has been entered.
Follow https://wpdevdesign.com/condition-acf-field-not-empty/.
data:image/s3,"s3://crabby-images/29fec/29fec4e7e47f4c5eb2c6dedc5134755d81078c4e" alt=""