在WordPress中,get_post_meta()
和 update_post_meta()
是两个非常有用的函数,它们允许你管理自定义字段,这些字段可以用来存储与帖子(posts)、页面(pages)或其他自定义帖子类型(custom post types)相关的额外信息。
以下是如何使用这两个函数的基本指南:
1. 获取自定义字段值:get_post_meta()
get_post_meta()
函数用于从数据库中检索与特定帖子关联的自定义字段值。
函数原型如下:
mixed get_post_meta( int $post_id, string $key, bool $single = false )
$post_id
:帖子的ID。$key
:自定义字段的键名。$single
:如果设置为true
,函数将返回单个值。如果设置为false
(默认值),函数将返回一个数组。
示例代码:
$post_id = 42; // 假设这是你要获取自定义字段的帖子的ID
$meta_key = 'my_custom_field'; // 自定义字段的键名
// 获取单个值
$meta_value = get_post_meta( $post_id, $meta_key, true );
// 获取多个值(数组)
$meta_values = get_post_meta( $post_id, $meta_key );
echo "Single Value: " . $meta_value;
print_r($meta_values); // 打印数组
2. 更新自定义字段值:update_post_meta()
update_post_meta()
函数用于更新与特定帖子关联的自定义字段值。
函数原型如下:
bool update_post_meta( int $post_id, string $meta_key, mixed $meta_value, mixed $prev_value = '' )
$post_id
:帖子的ID。$meta_key
:自定义字段的键名。$meta_value
:要更新的值。$prev_value
:可选参数,只有当自定义字段的当前值与$prev_value
匹配时,才会更新。
示例代码:
$post_id = 42; // 假设这是你要更新自定义字段的帖子的ID
$meta_key = 'my_custom_field'; // 自定义字段的键名
$meta_value = 'New Value'; // 新的值
// 更新自定义字段
$update_success = update_post_meta( $post_id, $meta_key, $meta_value );
if ( $update_success ) {
echo "Meta value updated successfully.";
} else {
echo "Meta value update failed.";
}
如果你想要添加一个新的自定义字段,而不是更新一个已存在的字段,你可以使用 add_post_meta()
函数,该函数在字段不存在时添加新字段。
请注意,当使用这些函数时,你应该确保自定义字段的键名是唯一的,并且遵循一定的命名约定,以避免与WordPress内置的字段冲突。通常,自定义字段键名以 _
开头是一个好习惯,尽管这不是强制性的。