Для чего используется параметр 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, а не через slug, и это работает:

//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.