Je suis en train d'insérer un post dans wordpress en utilisant la fonction wp_insert_post () .
Je souhaite insérer des champs personnalisés sur chaque publication et lire la documentation. Même si le paramètre meta_info a été utilisé pour cela, j'ai essayé quelque chose comme ceci:
$data = array(
'post_author' => 1,
'post_status' => 'publish',
'post_title' => $post->getTitle(),
'post_content' => $post->getContent(),
'post_category' => $post->getCategory(),
'tags_input' => $post->getTags(),
'meta_input' => array( "_test" => "testx1" )
);
$postID = wp_insert_post( $data );
Le message est inséré correctement et comporte également des balises. Mais il n'y a pas de champs personnalisés ajoutés. Je sais que je pourrais utiliser add_post_meta () pour les ajouter, mais j'aimerais quand même savoir à quoi sert le paramètre meta_input , car j'ai effectué une recherche dans la base de données pour "testx1" après avoir inséré le message et n'a pu trouver aucun résultat.
Cette partie de wp_insert_posts()
le donne:
if ( ! empty( $postarr['meta_input'] ) ) {
foreach ( $postarr['meta_input'] as $field => $value ) {
update_post_meta( $post_ID, $field, $value );
}
}
où nous voyons comment les champs de méta post sont mis à jour/ajoutés avec update_post_meta()
.
Voici la description en ligne de meta_input
:
Tableau de valeurs post-méta définies par leur clé post-méta. Par défaut vide.
Cela a été ajouté dans WordPress 4.4 et voici le billet pertinent # 20451 pour plus d'informations.
Notez que le trait de soulignement situé devant la clé méta _test
le masquera dans les champs custom custom metabox de l’écran de post-édition.
La façon dont je le fais est via term_id pas slug et cela fonctionne:
//insert Art items into database
$arr = array('item 1', 'item 2');
// $arr = array('art item 1', 'art item 2');
foreach ($arr as $a) {
wp_insert_post(array(
//essentials
//'ID' => 1131,
'post_author' => 1,
'post_title' => $a,
'post_type' => 'post',
'post_content' => 'Something...',
'post_status' => 'publish',
'post_name' => 'post name',
'meta_input' => array( //(array) Array of post meta values keyed by their post meta key. Default empty.
'city' => '',// 'name' => $post['name']
'country' => ''// 'city' => $post['city']
),
'tax_input' => array(
'category' => array(33,32), //id numbers work, slugs tend to be ignored !!!
'post_tag' => array('one', 'two') //for tags slugs seem to work
),//(array) Array of taxonomy terms keyed by their taxonomy name. Default empty. Equivalent to calling wp_set_post_terms() / wp_set_object_terms()
//'tags_input' => array('una', 'trei'), //(array) Array of tag names, slugs, or IDs. Default empty. Equivalent to calling wp_set_post_tags().
), true);
}