Test Mobile

Her eis

Alt text (short for “alternative text”) is an incredibly useful piece of markup that can be added to images. It is extremely useful for both accessibility and SEO purposes. It allows visually impaired readers as well as search engines to understand what content is contained within an image.

We do a lot of custom theme development here at Endo Creative and one of our favorite tools to use is Advanced Custom Fields (ACF). We were recently working on a project where we needed to pull in both the image url and the image alt text as well as have the ability to add specific classes. We created a simple function since we would need to do this many places throughout the theme utilizing both ACF fields and ACF sub-fields.

Here’s the function we added to our custom-functions.php file:

// Load in ACF image with alt text
function get_acf_image_with_alt( $imagefield, $postID, $imagesize = ‘full’, $subfield = false, $class = ” ) {
if ( $subfield == true ) {
$imageID = get_sub_field( $imagefield, $postID );
}
else {
$imageID = get_field( $imagefield, $postID );
}
$image = wp_get_attachment_image_src( $imageID, $imagesize );
$alt_text = get_post_meta( $imageID , ‘_wp_attachment_image_alt’, true );
return ‘<img src=”‘ . $image[0] . ‘” class=”‘ . $class . ‘” alt=”‘ . $alt_text . ‘” />’;
}

view rawget_acf_image_with_alt hosted with ❤ by GitHub

Here’s a breakdown of how each variable is being used:

$imagefield – is the name of your custom field in ACF
$postID – lets the function know which post the image is tied to
$imagesize – is set to ‘full’ by default, but you can specify the images size if needed
$subfield – we used a lot of ACF repeaters and groups in this project, so depending on what we were doing sometimes the image was an ACF subfield… this is set to ‘false’ by default but can be changed to ‘true’ if needed to use the correct ACF function
$class – an empty string by default, but can be used to add classes to the returning image element

First the function checks to see if it is looking for an ACF field or an ACF sub-field. Then the function will then use ACF’s function of get_field() or get_sub_field() to pull in the image accordingly.

Note: You will want to set the Return Format to Image ID.

A screenshot of the choices available for returning an Advanced Custom Field image

Next the function will use a WP function to get the source url of the image. It will then use a WP function to get the alt text associated with that image. Finally, the function will return an image element with the source url, any classes you have added, and the associated alt text.

This can then be easily echoed out in the theme while keeping your template code from getting too cluttered.

Here’s an example:

<a class=”member” href=”<?php the_permalink(); ?>”>
<?php echo get_acf_image_with_alt( ‘serious_photo’, get_the_ID(), ‘team-member’, false, ‘serious-photo’ ); ?>
<?php echo get_acf_image_with_alt( ‘funny_photo’, get_the_ID(), ‘team-member’, false, ‘funny-photo’ ); ?>
<p class=”name”><?php the_title(); ?></p>
<p class=”title”><?php the_field( ‘team_page_title’ ); ?></p>
</a>

view rawget_acf_image_with_alt-example.html hosted with ❤ by GitHub

Here we are running a WP Query to pull in photos of each team member to be displayed on the team page. We created a custom post type for team members and added an ACF field for their serious photo and an ACF field for their funny photo. We’re alternating between photos upon hover.

An example of code output from using the get ACF img with alt text function.