get_post_custom( int $post_id ): mixed
Retrieves post meta fields, based on post ID.
Contents
Description
The post meta fields are retrieved from the cache where possible, so the function is optimized to be called more than once.
Parameters
-
$post_id
int Optional -
Post ID. Default is the ID of the global
$post
.
Return
mixed An array of values.
False for an invalid $post_id
(non-numeric, zero, or negative value).
An empty string if a valid but non-existing post ID is passed.
More Information
See also get_post_custom_keys() and get_post_custom_values()
Source
File: wp-includes/post.php
.
View all references
function get_post_custom( $post_id = 0 ) {
$post_id = absint( $post_id );
if ( ! $post_id ) {
$post_id = get_the_ID();
}
return get_post_meta( $post_id );
}
Changelog
Version | Description |
---|---|
1.2.0 | Introduced. |
User Contributed Notes
You must log in before being able to contribute a note or feedback.
Default Usage
Use the following example to set a variable ($custom_fields) as a multidimensional array containing all custom fields of the current post.
Retrieving data from the array
The following example will retrieve all custom field values with the key my_custom_field from post ID 72 (assuming there are three custom fields with this key, and the values are “dogs”, “47” and “This is another value”).
0 => dogs
1 => 47
2 => This is another value
Note: not only does the function return a multi-dimensional array (ie: always be prepared to deal with an array of arrays, even if expecting array of single values), but it also returns serialized values of any arrays stored as meta values. If you expect that possibly an array may be stored as a metavalue, then be prepared to maybe_unserialize.