Ich füge einen Beitrag in WordPress mit der Funktion wp_insert_post () ein.
Ich möchte einige benutzerdefinierte Felder in jeden Beitrag einfügen und die Dokumentation lesen, obwohl der Parameter meta_info dafür verwendet wurde. Ich habe Folgendes versucht:
$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 );
Der Beitrag wird korrekt eingefügt und markiert auch. Es wurden jedoch keine benutzerdefinierten Felder hinzugefügt. Ich weiß, dass ich add_post_meta () verwenden könnte, um sie hinzuzufügen, aber ich möchte trotzdem wissen, wofür der Parameter meta_input verwendet wird, da ich in der Datenbank nach "testx1" gesucht habe. nach dem Einfügen des Beitrags und konnte kein Ergebnis finden.
Dieser Teil von wp_insert_posts()
gibt es weg:
if ( ! empty( $postarr['meta_input'] ) ) {
foreach ( $postarr['meta_input'] as $field => $value ) {
update_post_meta( $post_ID, $field, $value );
}
}
hier sehen wir, wie die Post-Meta-Felder mit update_post_meta()
aktualisiert/hinzugefügt werden.
Hier ist die Inline-Beschreibung für meta_input
:
Array von Post-Meta-Werten, die durch ihren Post-Meta-Schlüssel verschlüsselt sind. Standardmäßig leer.
Dies wurde in WordPress 4.4 hinzugefügt und hier ist das relevante Ticket # 20451 für weitere Informationen.
Beachten Sie, dass die Verwendung des Unterstrichs vor dem Metaschlüssel _test
ihn vor der Metabox benutzerdefinierte Felder im Post-Edit-Bildschirm verbirgt.
Die Art und Weise, wie ich es mache, ist über term_id nicht slug und es funktioniert:
//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);
}