Для чого використовується параметр “meta_input” у wp_insert_post ()?


10

Я вставляю деяку публікацію в wordpress за допомогою функції wp_insert_post () .

Я хочу вставити деякі користувальницькі поля на кожен пост і читати документацію. Я хоч для цього використовувався параметр meta_info, я спробував щось подібне:

$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 );

Публікацію вставлено правильно та також теги. Але не додано спеціальних полів. Я знаю, що я міг би використовувати add_post_meta (), щоб додати їх, але я все одно хотів би знати, для чого використовується параметр meta_input , тому що я здійснив пошук у базі даних для "testx1" після вставки повідомлення і не зміг знайти жодного результату.

Відповіді:


7

Ця частина wp_insert_posts()дарує це:

  if ( ! empty( $postarr['meta_input'] ) ) {
        foreach ( $postarr['meta_input'] as $field => $value ) {
            update_post_meta( $post_ID, $field, $value );
        }
  } 

де ми бачимо, як оновлюються / додаються метаполя публікації update_post_meta().

Ось вбудований опис для meta_input:

Масив мета-значень публікацій, введених їх метаметофоном пост. За замовчуванням порожній.

Це було додано у WordPress 4.4, і ось додатковий квиток № 20451 для отримання додаткової інформації.

Зауважте, що використання підкреслення перед мета-клавішею _testприховає його від метабокса спеціальних полів на екрані редагування публікацій.


Ох, тестування WP ім на 4.3, велике спасибі.
streel

0

Як я це роблю, це через term_id, а не сліз, і це працює:

//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);   
}
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.