Overview
Need to dynamically populate a field’s choices? This tutorial shows how to take a value saved to an options page and use it to override the choices
array for a Select field.
The ‘choices’ array attribute is also used with the Radio Button and Checkbox fields. Most of this tutorial applies to any of these fields, but the AJAX example can only be used with the Select field.
Requirements
This tutorial requires the use of the acf/load_field filter, in conjunction with the name
modifier to apply the filter to all fields of a specific name
. The name
attribute is how the field is stored and referred to in the WordPress database.
Populating Choices From a Text Area Field
In this example, we will load a Text Area field called my_select_values
from an options page, and use the text on each line as an option for the Select field’s choices. The Select field’s name
in this example is color
.
functions.php
function acf_load_color_field_choices( $field ) {
// Reset choices
$field['choices'] = array();
// Get the Text Area values from the options page without any formatting
$choices = get_field('my_select_values', 'option', false);
// Explode the value so each line is a new element in the array
$choices = explode("\n", $choices);
// Remove unwanted white space
$choices = array_map('trim', $choices);
// Loop through the array and add to field 'choices'
if( is_array($choices) ) {
foreach( $choices as $choice ) {
$field['choices'][ $choice ] = $choice;
}
}
// Return the field
return $field;
}
add_filter('acf/load_field/name=color', 'acf_load_color_field_choices');
Populating Choices From a Repeater Field
In this example, we will load a Repeater field called my_select_values
from the options page, and use the subfields value
and label
as the options for the Select field’s choices.
functions.php
function acf_load_color_field_choices( $field ) {
// Reset choices
$field['choices'] = array();
// Check to see if Repeater has rows of data to loop over
if( have_rows('my_select_values', 'option') ) {
// Execute repeatedly as long as the below statement is true
while( have_rows('my_select_values', 'option') ) {
// Return an array with all values after the loop is complete
the_row();
// Variables
$value = get_sub_field('value');
$label = get_sub_field('label');
// Append to choices
$field['choices'][ $value ] = $label;
}
}
// Return the field
return $field;
}
add_filter('acf/load_field/name=color', 'acf_load_color_field_choices');
Populating a Select Field With AJAX
Unlike the Radio Button and Checkbox fields, the Select field can be populated via AJAX. This can help speed up page load times when using the acf/load_field
filter to populate the Select field’s choices. The Select field must have “Stylized UI” and “Use AJAX to lazy load choices” turned on for this filter to work. The “Use AJAX to lazy load choices” option is hidden until “Stylized UI” is turned on in the Select field’s settings.
function filter_field( array $field ) : array {
if ( defined( 'DOING_AJAX' ) && DOING_AJAX ) {
$field['choices'] = time_consuming_call_to_get_choices();
}
return $field;
}
add_filter( "acf/load_field/key=$key", 'filter_field', 10, 1 );