Fre*_*rik 4 wordpress custom-fields
我正在尝试通过 wp_update_post 函数更新我的一篇帖子中的帖子内容。我已阅读此处的文档:http ://codex.wordpress.org/Function_Reference/wp_update_post
如果我做对了,我只需要发送帖子 ID 和我想要更新的帖子内容 - 就像示例中一样 - 这应该是唯一会改变的事情。尽管我附加到这篇文章的自定义字段消失了,但很奇怪。
我传递了以下代码:
if(isset($_POST['submit'])){
$the_post = array();
$the_post['ID'] = $_POST['id'];
$the_post['post_content'] = $_POST['recension'];
// Update the post into the database
wp_update_post( $the_post );
}
Run Code Online (Sandbox Code Playgroud)
为什么会发生这种情况以及如何解决?
小智 5
这是因为当您更新帖子时,会使用 *wp_insert_post* 函数,并且有“save_post”(1) 操作挂钩,通常用于保存自定义字段数据。
添加/更新帖子元的标准方法是这样的:
$post_meta['_mymeta'] = $_POST['_mymeta'];
// Add values of $events_meta as custom fields
foreach ($events_meta as $key => $value) { // Cycle through the $post_meta array!
if( $post->post_type == 'revision' ) return; // Don't store custom data twice
if($value && $value != get_post_meta($post->ID, $key, TRUE)) { // If the custom field already has a value
update_post_meta($post->ID, $key, $value);
} elseif($value && get_post_meta($post_id, $key, TRUE) == "") { // If the custom field doesn't have a value
add_post_meta($post->ID, $key, $value, TRUE);
}
if(!$value) delete_post_meta($post->ID, $key, get_post_meta($post->ID, $key, TRUE)); // Delete if blank
}
Run Code Online (Sandbox Code Playgroud)
...如您所见,它正在检查 *$_POST* 数据,如果它为空或未设置,它将用空数据更新您的元值或将其完全删除。
我想你应该使用数据库更新函数或其他一些 API 函数来更新帖子字段...例如这段代码将更新你的帖子菜单顺序:
$wpdb->update( $wpdb->posts, array( 'menu_order' => 5 ), array( 'ID' => $post->ID ) );
Run Code Online (Sandbox Code Playgroud)
(1) 每当创建或更新帖子或页面时运行,这可以来自导入、帖子/页面编辑表单、xmlrpc 或通过电子邮件发布。操作函数参数:帖子 ID。
| 归档时间: |
|
| 查看次数: |
4522 次 |
| 最近记录: |