ACF Google and Open Street Map Fields: Extensive Guide
Key Points at a Glance
- ACF Google Map Field: Allows adding a single marker on Google Maps with coordinates and zoom level stored in metadata.
- API Key Setup: Google Maps fields in ACF require an API key, which can be set via custom code or ACF Options page for easier management.
- Multiple Markers Field: ACF Multiple Google Markers field allows multiple markers on a single map, unlike the default Google Map field.
- OSM Field Add-On: The ACF OpenStreetMap field supports multiple markers, requires no API key, and integrates with Leaflet.js.
- ACF Map Display: Displaying Google Maps requires enqueuing and setting up the Google Maps JS library or can be simplified by using the Advanced Views Framework.
- Querying Map Data: ACF map fields store data as serialized arrays, making direct querying limited.
Table of Contents
The ACF Google Map is a multi-part field type within the Advanced Custom Fields plugin, categorized under the "Advanced" group. It allows editors to locate a specific area using the map widget, place a marker, save the marker's coordinates, and zoom level into metadata.
However, the ACF plugin doesn't provide a dedicated field type for OpenStreetMap (OSM) by default, and the Google Map field is limited to storing only a single marker.
Fortunately, the active ACF community has developed several add-ons that introduce new field types, such as the ACF OSM Field and ACF Multiple Google Markers Field.
These field types function similarly to the default Google Map field, allowing editors to interact with a map, add markers, and store multiple coordinates in object metadata.
Iframe oEmbed alternative
Aside from using a Map field in plugins like ACF, there's a simpler alternative for embedding maps in WordPress: using iframes. Both Google Maps and OSM offer an iframe oEmbed option, allowing you to visit their websites, select a location, and generate a code to embed directly on your site.
You can also set up a marker to highlight a specific spot on the map. For a step-by-step guide, read our on How to Embed a Map in WordPress using Iframe in our dedicated article.
This method is straightforward and doesn’t require any plugins, making it perfect for one-time map embeds, like on a contact page. However, it’s not ideal for Custom Post Types (CPT) or scenarios requiring multiple embeds, as it lacks a built-in map selection widget for editors.
In case you've opted for the Map field usage, let's go on with the ACF Map fields review.
ACF Google Map field UI
The Google Map widget allows you to define an address not only by drag-and-drop scrolling but also by entering the desired address into the autocomplete input field.
Note: Keep in mind that the 'autocomplete' address feature works only for editors, so if you need, for example, the autocomplete address for WooCommerce checkout, this field doesn't fit directly.
Map fields in other meta-field plugins
If you're exploring alternatives to ACF, similar Map fields can be found in the Meta Box plugin, which supports both Google Maps and OpenStreetMap fields. On the other hand, the Pods plugin does not provide a direct alternative for map fields.
For a deeper look at the differences between ACF and Meta Box plugins, check out our detailed comparison of the best meta field plugins to understand which one suits your needs best.
1. Google vs. OpenStreetMap
The primary decision to make when using ACF Map fields is choosing which map vendor to use.
Google Maps offers a familiar and feature-rich interface, but it requires an API key and follows a freemium pricing model. This means that while Google provides some free usage credits each month, any usage beyond this limit incurs charges, which can add up quickly, especially for high-traffic sites.
OpenStreetMap, on the other hand, is an open-source, completely free option with no usage limits. It’s an ideal choice if you have no specific requirements tied to Google’s ecosystem. OSM is also a privacy-friendly alternative, as it doesn’t collect user data like Google Maps.
For more insights into the differences between these vendors, check out our comprehensive guide on Embedding Maps in WordPress.
2. ACF Google Map field essentials
2.1) Field settings
- Center Lat/Lng
This setting allows you to set the default center of the map by entering latitude and longitude coordinates. This is particularly useful for setting a specific starting point on the map. - Zoom Level
This setting controls the initial zoom level of the map when it's loaded. Higher values mean closer zoom, while lower values provide a wider view of the area. - Height
The height setting defines the vertical size of the map widget in the editor. This is purely for the backend and doesn't affect the frontend display.
The Google Map field settings in ACF do not provide an option to enter an API key directly. The reason for this is that the API key should be consistent and shared across all Google Map fields on the site to ensure seamless functionality and easy management.
To set up the API key, you'll need to add a custom code snippet. We'll cover it separately in a short time.
2.2) Storage format and supported field locations
The data from the ACF Google Map field is stored as a serialized array in the WordPress metadata. This array contains detailed information about the chosen location, including coordinates, address, and additional geographical data. Here’s an example of what the stored data looks like:
a:9:{
s:7:"address";s:32:"XVJP+GV Andasibefasy, Madagascar";
s:3:"lat";d:-20.0186875;
s:3:"lng";d:45.8871875;
s:4:"zoom";i:5;
s:8:"place_id";s:100:"EiFYVkpQK0dWLCBBbmRhc2liZWZhc3ksIE1hZGFnYXNjYXIiJjokCgoNBWQR9BVD1FkbEAoaFAoSCeXzmYlI6uMhEW5ofOqrJsUx";
s:4:"city";s:12:"Andasibefasy";
s:5:"state";s:14:"Amoron'i Mania";
s:7:"country";s:10:"Madagascar";
s:13:"country_short";s:2:"MG";
}
Supported field locations
The ACF Map field can be applied across various locations in WordPress, allowing you to store geographical data consistently, regardless of where the field is used:
- Post Objects (Posts, Pages, Media Attachments, Custom Post Types, WooCommerce Products):
The ACF Map field can be attached to any post object, including standard posts, pages, media attachments, and custom post types (CPTs). The map data, including coordinates, address, and other location details, are stored in the wp_postmeta table, linked to the respective post or custom post type item. - Options Page:
The Map field can also be used on ACF Options Pages, storing location data in the wp_options table. This makes the map settings accessible globally, which is particularly useful for site-wide features such as a store locator or a central business address. - User Profiles:
Adding the Map field to user profiles allows you to capture location data specific to each user. The map coordinates and other location details are stored in the wp_usermeta table, connected to the relevant user. This setup can be useful for user-specific location data, like user-reported locations or delivery addresses. - Terms (e.g., Post Categories, Tags, Custom Taxonomies):
The Map field can be attached to terms such as post categories, tags, or custom taxonomies. The stored map data is saved in the wp_termmeta table, linked to the specific term, making it a great option for location-based categorization, such as event types, regions, or areas. - ACF Gutenberg Block:
The ACF Map field can be integrated into custom ACF Gutenberg blocks. When used in a block, the map data is stored within the post_content as part of the block's JSON data structure in the wp_posts table. This makes it an ideal choice for dynamic content placement, such as embedding maps directly within block layouts.
2.3) Return value format
The ACF Map field returns an array containing all the available location data stored in the database. This array provides comprehensive information about the selected place, which includes coordinates, address details, and other metadata. Below is an example of the returned array with all available keys:
$location_info = [
'address' => 'XVJP+GV Andasibefasy, Madagascar',
'lat' => -20.0186875,
'lng' => 45.8871875,
'zoom' => 5,
'place_id' => 'EiFYVkpQK0dWLCBBbmRhc2liZWZhc3ksIE1hZGFnYXNjYXIiJjokCgoNBWQR9BVD1FkbEAoaFAoSCeXzmYlI6uMhEW5ofOqrJsUx',
'city' => 'Andasibefasy',
'state' => 'Amoron\'i Mania',
'country' => 'Madagascar',
'country_short' => 'MG'
];
2.4) Google API key
To use the Google Map field in ACF, you need to register a Google Maps API key. Follow the official Google tutorial to get your API key. Once you have the key, you can register it with ACF in one of the following ways:
Using a common map field filter
add_filter('acf/fields/google_map/api', function ( array $api ): array {
$api['key'] = 'YOUR_API_KEY'; // Replace 'YOUR_API_KEY' with your actual key
return $api;
});
Using a global setting
add_action('acf/init', function() {
acf_update_setting('google_api_key', 'YOUR_API_KEY'); // Replace 'YOUR_API_KEY' with your actual key
});
In both cases, adding the code to the functions.php file will hardcode the API key, which is quick but not easily editable.
Recommended approach: adding the API Key via the ACF Options page
For greater flexibility, it's recommended to add a text field to the ACF Options page. This approach allows site administrators or editors to update the API key directly from the WordPress admin panel without editing code. If you opt for this setup, your code snippet will look like this:
add_filter('acf/fields/google_map/api', function ( array $api ): array {
$api['key'] = get_field('my_text_api_key_field', 'option'); // Fetches the API key from a text field on the Options page
return $api;
});
3. ACF Multiple Google Map Markers field
The ACF Multiple Google Markers addon introduces a new field type specifically designed for handling multiple markers on a single Google map. This field type comes with the same settings as the standard ACF Google Map field, such as center latitude/longitude, zoom level, and height.
However, it adds an important additional setting: the 'Max Pins' option, which allows you to define the maximum number of markers that can be placed on the map.
Note: This field type doesn't automatically appear within your usual field groups. To select it in the field type browser popup, type "map" in the search box, and choose the Google Maps (Multiple Markers) from the search results.
Return value format
The ACF Multiple Google Markers field returns an array of location data. Each entry in the array corresponds to a single marker and includes all relevant location details. Here’s an example of what the returned data looks like:
$locations = [
[
'address' => '9QCW+J5 Zlynets, Rivne Oblast, Ukraine',
'lat' => 50.371516139562,
'lng' => 25.79547825224,
'zoom' => 7,
'place_id' => 'GhIJ_7ft1o0vSUARfC1Dd6TLOUA',
'city' => 'Zlynets',
'state' => 'Rivne Oblast',
'post_code' => '35652',
'country' => 'Ukraine',
'country_short' => 'UA'
],
[
'address' => 'XVG6+V9 Polonycheve, Zhytomyr Oblast, Ukraine',
'lat' => 50.977227809162,
'lng' => 27.86090793974,
'zoom' => 7,
'place_id' => 'GhIJ-t7wzBV9SUARN17LdWTcO0A',
'city' => 'Polonycheve',
'state' => 'Zhytomyr Oblast',
'post_code' => '11210',
'country' => 'Ukraine',
'country_short' => 'UA'
]
];
4. ACF Open Street Map field
The ACF OpenStreetMap addon introduces a new field type specifically for OpenStreetMap. This field is highly flexible and supports multiple markers by default.
Key Benefits:
- No API keys required:
Unlike Google Maps, the OSM field does not require API keys, simplifying the setup process and eliminating associated costs. - Built-in leaflet support:
The addon comes with built-in support for Leaflet, a popular open-source mapping library. This integration allows you to display the map on the front end without needing to write custom JavaScript code.
Storage format
Unlike Google Maps, the OSM response provides much richer location data. Below is an example of the data stored in the metadata for OSM field:
$result = [
'lat' => 53.4095319,
'lng' => 9.041748,
'zoom' => 9,
'markers' => [
[
'label' => 'Friedrichsdorf, 27442 Gnarrenburg Friedrichsdorf, Lower Saxony Germany',
'default_label' => 'Friedrichsdorf, 27442 Gnarrenburg Friedrichsdorf, Lower Saxony Germany',
'lat' => 53.4095148,
'lng' => 9.0394558,
'geocode' => [
[
'name' => 'Friedrichsdorf, Gnarrenburg, Landkreis Rotenburg (Wümme), Lower Saxony, 27442, Germany',
'html' => 'Friedrichsdorf, 27442 Gnarrenburg Friedrichsdorf, Lower Saxony Germany',
'center' => [
'lat' => 53.408440031458,
'lng' => 9.0407555352178
],
'bbox' => [
'_southWest' => [
'lat' => 53.408440031458,
'lng' => 9.0407555352178
],
'_northEast' => [
'lat' => 53.408440031458,
'lng' => 9.0407555352178
]
],
'properties' => [
'place_id' => 164558606,
'licence' => 'Data © OpenStreetMap contributors, ODbL 1.0. http://osm.org/copyright',
'osm_type' => 'way',
'osm_id' => 29346103,
'lat' => 53.4084400314582,
'lon' => 9.040755535217812,
'class' => 'highway',
'type' => 'residential',
'place_rank' => 26,
'importance' => 0.10001,
'addresstype' => 'road',
'name' => 'Friedrichsdorf',
'display_name' => 'Friedrichsdorf, Gnarrenburg, Landkreis Rotenburg (Wümme), Lower Saxony, 27442, Germany',
'address' => [
'road' => 'Friedrichsdorf',
'hamlet' => 'Friedrichsdorf',
'town' => 'Gnarrenburg',
'county' => 'Landkreis Rotenburg (Wümme)',
'state' => 'Lower Saxony',
'ISO3166-2-lvl4' => 'DE-NI',
'postcode' => '27442',
'country' => 'Germany',
'country_code' => 'de'
],
'boundingbox' => [
0 => 53.4058577,
1 => 53.4149309,
2 => 9.0386775,
3 => 9.0460674
]
]
]
],
'uuid' => 'marker_6540e48dce3e0'
]
],
'address' => 'Friedrichsdorf, 27442 Gnarrenburg Friedrichsdorf, Lower Saxony Germany',
'layers' => [
'OpenStreetMap.Mapnik'
],
'version' => '1.5.6',
'center_lat' => 53.4095319,
'center_lng' => 9.041748
];
We'll review how to display the OSM map on the front in detail in the Code snippets chapter below.
5. Use cases of the ACF Map field
ACF Map is a versatile field type and can be used in various use cases, including:
- Contact page
Adding a map to your contact page is one of the most common uses of the ACF Map field. - CPT item location (e.g., Events or Real estate listings)
For Custom Post Types like Events, the ACF Map field can be used to display the event location on the map. - Taxonomy Terms (e.g., Cities)
The ACF Map field can also be used with taxonomy terms to display locations related to categories or tags. This is useful for sites with geographical content or when categorizing posts based on locations. - User Profiles
Integrate the ACF Map field into user profiles to allow users to specify their locations. This can be particularly useful for sites where user location is relevant, such as in directories, networking platforms, or service provider listings.
6. All WordPress CPT items on a single map
The straightforward use of Map fields typically involves displaying a location map on a single template (such as a page or CPT). However, you may also want to show all items of a specific CPT on a single map page.
Both Google Maps and OpenStreetMap (OSM) fields lack a built-in feature to display multiple items on one map. Thankfully, because these map fields store location data in the metadata, you can achieve this with some custom development.
To do this, you'll need to query the CPT items, gather their location data, and pass it to the frontend. You will then use custom JavaScript to initialize the map and add the locations as markers. This approach allows you not only to display all items on a single map but also to show a custom popup with details when clicking on a marker.
While it may seem complex, the process is quite manageable. For a detailed step-by-step guide, refer to the How to display all WordPress CPT items on a single map section in our Embed map in WordPress article.
7. Code snippets for the ACF Map Field
ACF provides hooks and functions for customizing and displaying field values. Direct API usage offers flexibility but requires familiarity with ACF and experience.
To streamline development, you can use the Advanced Views Framework, which simplifies query and display tasks while allowing full control over markup. It supports all ACF field types out of the box, along with other data vendors.
7.1) Setting up the Google map API key
Here is a copy of the snippet mentioned in the Essentials chapter for quick reference. You can add this snippet to the functions.php file of your theme:
add_filter('acf/fields/google_map/api', function ( array $api ): array {
$api['key'] = 'YOUR_API_KEY'; // Replace 'YOUR_API_KEY' with your actual key
return $api;
});
7.2) Displaying Google map widget
Unlike the OSM map field addon, the built-in Google Map field does not assist with front-end display. This means you need to enqueue the Google Maps library and initialize the map instance yourself. A simpler approach is to use the Advanced Views Framework, which handles these tasks for you.
Below are examples for both Advanced Views and ACF functions:
Using Advanced Views Framework
Complete the following steps:
- Install the Advanced Views Framework:
Begin by installing and activating the AVF plugin on your WordPress site. - Create a View:
Set up a new View within AVF and select the target Google Map field that you want to display. - Publish the View:
Click the "Publish" button to create the View. - Copy the Shortcode:
From the right sidebar, copy the generated shortcode. - Paste the Shortcode:
Paste this shortcode into the desired location on your page or post.
That's it! AVF will automatically handle retrieving the field’s data, enqueuing the Google Maps script, and initializing the map instance for you. If needed, you can customize the generated View template to add headings or other elements.
In the Pro version, you can also define a custom map marker, display the location data as text, and also turn any View into a custom Gutenberg block!
Using custom theme code
To display the Google Map manually, you'll need to pass the location data to the front end and initialize the map instance yourself.
For the markup creation, use the following code:
<?php
// TODO your field name here
$mapInfo = get_field("map");
$zoom = $mapInfo['zoom'] ?? '16';
$lat = $mapInfo['lat'] ?? '';
$lng = $mapInfo['lng'] ?? '';
// zoom level - gets from every specific map (when admins zoom out and saves a page, the zoom is also saved)
printf(
'<div class="my-map" style="width:100%%;height:400px;" data-zoom="%s">',
$zoom
);
printf(
'<div class="my-map__marker" data-lat="%s" data-lng="%s"></div>',
esc_attr($lat),
esc_attr($lng)
);
echo "</div>";
Next, enqueue the Google Maps script by adding the following code to your theme's functions.php file. This script will retrieve the registered API key (as described previously) and enqueue the Google Maps API script:
<?php
add_action('wp_footer', function () {
$apiData = apply_filters('acf/fields/google_map/api', []);
$key = $apiData['key'] ?? '';
$key = !$key ?
acf_get_setting('google_api_key') :
$key;
if (!$key) {
return;
}
wp_enqueue_script(
'google-maps',
sprintf('https://maps.googleapis.com/maps/api/js?key=%s&callback=googleMapsCallback', $key),
null,
true
);
});
Pro tip: For better performance, we recommend adding some checks, to make sure this only loads on pages where the map exists. E.g. Limit it to a single page by URL with is_page, or to the CPT type with is_singular.
Now it's time to create the JS code which will initialize our map. You can place the code into the script.js file of your theme. Note that we define the googleMapsCallback window property, which is used in the script enqueue as well. This is how we connect the script with the callback function for initializing the map.
class Map {
constructor(element) {
this.element = element
this.map = null
this.mapMarkers = []
}
readMarkers() {
// TODO replace the selector if you've changed it in the markup
this.element.querySelectorAll('.my-map__marker').forEach((markerElement) => {
let lat = markerElement.dataset.hasOwnProperty('lat') ?
markerElement.dataset['lat'] :
0
let lng = markerElement.dataset.hasOwnProperty('lng') ?
markerElement.dataset['lng'] :
0
this.mapMarkers.push({
lat: parseFloat(lat),
lng: parseFloat(lng),
})
markerElement.remove()
})
}
createMap() {
let mapArgs = {
zoom: parseInt(this.element.dataset.hasOwnProperty('zoom') ?
this.element.dataset['zoom'] :
16),
mapTypeId: window.google.maps.MapTypeId.ROADMAP,
}
this.map = new window.google.maps.Map(this.element, mapArgs)
}
createMarkers() {
this.mapMarkers.forEach((marker) => {
new window.google.maps.Marker({
position: marker,
map: this.map,
})
})
}
centerMap() {
// Create map boundaries from all map markers.
let bounds = new window.google.maps.LatLngBounds()
this.mapMarkers.forEach((marker) => {
bounds.extend({
lat: marker.lat,
lng: marker.lng,
})
})
if (1 === this.mapMarkers.length) {
this.map.setCenter(bounds.getCenter())
} else {
this.map.fitBounds(bounds)
}
}
init() {
if (!window.hasOwnProperty('google') ||
!window.google.hasOwnProperty('maps') ||
!window.google.maps.hasOwnProperty('Map') ||
!window.google.maps.hasOwnProperty('Marker') ||
!window.google.maps.hasOwnProperty('LatLngBounds') ||
!window.google.maps.hasOwnProperty('MapTypeId') ||
!window.google.maps.MapTypeId.hasOwnProperty('ROADMAP')) {
console.log('Google maps isn\'t available')
return
}
// before the map initialization, because during creation HTML is changed
this.readMarkers()
this.createMap()
this.createMarkers()
this.centerMap()
}
}
class Maps {
constructor() {
this.isMapsLoaded = false
this.mapsToInit = []
// TODO change to yours if you've defined own callback (for https://maps.googleapis.com/maps/api...)
window.googleMapsCallback = this.mapsLoadedCallback.bind(this)
'loading' !== document.readyState ?
this.setup() :
window.addEventListener('DOMContentLoaded', this.setup.bind(this))
}
setup() {
const observer = new MutationObserver((records, observer) => {
for (let record of records) {
record.addedNodes.forEach((addedNode) => {
this.addListeners(addedNode)
})
}
})
observer.observe(document.body, {
childList: true,
subtree: true,
})
this.addListeners(document.body)
}
mapsLoadedCallback() {
this.isMapsLoaded = true
this.mapsToInit.forEach((map) => {
map.init()
})
this.mapsToInit = []
}
addListeners(element) {
if (Node.ELEMENT_NODE !== element.nodeType) {
return
}
// TODO replace the selector if you've changed it in the markup
element.querySelectorAll('.my-map').forEach((mapElement) => {
let map = new Map(mapElement)
if (!this.isMapsLoaded) {
this.mapsToInit.push(map)
return
}
map.init()
})
}
}
new Maps()
That's it. Now you can visit the page and see the Google map as a part of your page.
7.3) Displaying OpenStreetMap widget
Using Advanced Views Framework
AVF supports the OSM map field type out of the box, so the steps will be exactly the same, as with the Google Map case:
- Install the Advanced Views Framework:
Begin by installing and activating the AVF plugin on your WordPress site. - Create a View:
Set up a new View within AVF and select the target OSM field that you want to display. - Publish the View:
Click the "Publish" button to create the View. - Copy the Shortcode:
From the right sidebar, copy the generated shortcode. - Paste the Shortcode:
Paste this shortcode into the desired location on your page or post.
That's it! AVF will automatically handle retrieving the field’s data, enqueuing the Leaflet script, and initializing the map instance for you. If needed, you can customize the generated View template to add headings or other elements.
Using custom theme code
The field has 3 Return formats, which control the ACF get_field function response. You should choose the Return format, which closer fits your goals. Keep in mind that, regardless of the return format setting, the location data is always stored as a serialized array in the database.
Below, we review displaying depending on the return format:
Leaflet JS return format
When this format is chosen, to display the map on the front end, you simply call:
echo get_field('osm_map');
It'll print the necessary markup, and the addon will enqueue leaflet.js and render the map without needing additional JavaScript code.
Iframe return format
This option changes the get_field function response and returns the iframe HTML. To display the map, use:
echo get_field('osm_map');
Raw data return format
In this case, you’ll need to manually enqueue the Leaflet or another mapping library and initialize the instance according to the library's documentation.
7.4) Setting a custom Google marker icon
By default, the Google Map displays a standard red marker icon. In some cases, it may be useful to use a custom marker icon instead.
Using Advanced Views Framework
The AVF: Pro edition allows you to choose a custom marker icon directly in the field settings. For more details, visit the AVF Google Map documentation.
Using custom theme code
In this case, we need to amend the map script. In the createMarkers method, while the marker creation we can pass the icon property (image URL), which will be used instead of the default markup:
createMarkers() {
this.mapMarkers.forEach((marker) => {
new window.google.maps.Marker({
position: marker,
map: this.map,
// todo replace with the path to your marker icon
icon: 'https://yoursite/your-icon.png',
})
})
}
7.5) Setting up a custom OSM marker icon
In case you're using a map field from the OSM addon, we've no control over the JS script, so we'll need to replace a marker icon on the server side.
Using Advanced Views Framework
OpenStreetMap field is supported by AVF, and the Pro version allows to set a custom marker icon right in the field settings. For more details, visit the AVF OSM field documentation.
Using custom theme code
While the addon doesn't provide a separate setting for customizing the icon, we can achieve it by using the following trick:
add_action( 'wp_footer', function () {
// todo put your source here
$icon = '<img class="custom-marker-icon" src="your_icon_source.png">';
// addslashed to avoid breaking the JSON code.
$new_part = sprintf( '"marker":{"html":"%s",', addslashes( $icon ) );
global $wp_scripts;
$data = $wp_scripts->get_data( 'acf-osm-frontend', 'data' );
$data = str_replace( '"marker":{"html":false,', $new_part, $data );
$wp_scripts->add_data( 'acf-osm-frontend', 'data', $data );
// it can be included as inline 'style=' for the icon, but for some reason it ignores the 'transform' property
// maybe Leaflet.js overrides or removes it.
echo '<style>.custom-marker-icon{position:absolute;bottom:50%;left:50%;transform: translateX(-50%);}</style>';
} );
This code can be added to the functions.php of your theme. It replaces the default icon with a custom one and prints the basic CSS to style it.
8. Querying by the ACF Map fields
ACF stores location data as a serialized array in the metadata, which means direct queries by specific fields like 'street' or 'lat' aren't possible. However, you can use the LIKE comparison to match items based on strings inside the array. For example, using LIKE '%Germany%' can help you find all locations in Germany.
However, this way, we can't find a location within some area by coordinates.
Unlike displaying, querying map fields can be more complex because ACF fields store data in various locations depending on the context (posts, users, options pages, etc.). Here's how to handle queries based on where the Map field values are stored:
8.1) By postmeta (Post, Page, Any CPT)
Using Advanced Views Framework:
If you're using the AVF: Pro edition, querying by ACF Map field values is straightforward with Meta Queries. You need to create a Card, choose the target Map field in the Meta Fields tab, and define the desired value. It can be a static id or pointer to another field. Make sure the comparison is equal to Contains and save the Card.
That's it! The framework will take care of the rest.
Using WP_Query
For custom queries, you can use the built-in WP_Query class:
$args = array(
'post_type' => 'post', // Replace with your custom post type if needed
'post_status' => 'publish',
'posts_per_page' => -1, // Retrieve all posts
'meta_query' => array(
array(
'key' => 'your_map_field', // Replace with your ACF Map field key
'value' => 'Germany', // put the target city or country here
'compare' => 'LIKE', // Use LIKE to search within the serialized array
)
)
);
// Execute the query
$query = new WP_Query($args);
// Loop through the results
foreach($query->get_posts() as $post){
// Process each WP_Post object here
// For example, you might display the post title or other details
echo '<h2>' . get_the_title($post->ID) . '</h2>';
}
8.2) By termmeta (Terms)
Here we need to employ the WP_Term_Query class:
$args = array(
'taxonomy' => 'category', // Replace with your taxonomy
'meta_query' => array(
array(
'key' => 'your_map_field', // Replace with your custom field key
'value' => 'Germany', // put the target city or country here
'compare' => 'LIKE', // Use LIKE to search within the serialized array
)
)
);
// Execute the query
$term_query = new WP_Term_Query($args);
// Loop through the results
foreach ($term_query->get_terms() as $term) {
// Process each WP_Term object
// Example: echo $term->name;
}
8.3) By usermeta (user profile)
In this case, we need to use the WP_User_Query class:
$args = array(
'meta_query' => array(
array(
'key' => 'your_map_field', // Replace with your custom field key
'value' => 'Germany', // put the target city or country here
'compare' => 'LIKE', // Use LIKE to search within the serialized array
)
)
);
$user_query = new WP_User_Query($args);
// Loop through the results
foreach ($user_query->get_results() as $user) {
// Process each WP_User object
// Example: echo $user->user_login;
}
8.4) Inside ACF Blocks
ACF Blocks save their data as JSON in the post_content. This data cannot be queried directly. However, if you enable the "Save in Meta" feature for ACF Blocks, the field values are also saved in post meta, allowing you to query them similarly to other postmeta fields.
Thank you for reading! to our monthly newsletter to stay updated on the latest WordPress news and useful tips.
Stuck with development or facing an issue?
WPLake offers affordable on-demand website development and design.
No matter the size of your project - contact us now, and we'll get it done for you!
Frequently Asked Questions Test Your Knowledge
FAQ mode
/
Learning mode
- Can I bind a custom marker popup to show custom info?
Yes, map markers can have their own popups with custom info. To achieve this, you'll need to customize the marker creation settings. Refer to the Google Maps library or Leaflet documentation for guidance, depending on the map vendor you are using.
- Can I make a location query to find items in a specific area?
Partially. Location information is stored as a serialized array, so you can query items based on broader criteria like city or country, which are string parts inside the array. However, narrowing the search to specific coordinates is not feasible because it's impossible to directly compare numbers inside serialized arrays in the database.
Content links (41)
15.
leafletjs.com30.
leafletjs.com
Thank you for the support.