Para que serve o parâmetro "meta_input" em wp_insert_post ()?


10

Estou inserindo algum post no wordpress usando a função wp_insert_post () .

Quero inserir alguns campos personalizados em cada post e ler a documentação. Embora o parâmetro meta_info tenha sido usado para isso, tentei algo como isto:

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

A postagem é inserida corretamente e as tags também. Mas não há campos personalizados adicionados. Eu sei que poderia usar add_post_meta () para adicioná-los, mas ainda gostaria de saber para que serve o parâmetro meta_input , porque fiz uma pesquisa no banco de dados por "testx1" depois de inserir a postagem e não encontrei nenhum resultado.

Respostas:


7

Esta parte do wp_insert_posts()apresenta:

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

onde vemos como os metapampos da postagem são atualizados / adicionados update_post_meta().

Aqui está a descrição embutida para meta_input:

Matriz de pós-metadados codificados por sua pós-metatec. Padrão vazio.

Isso foi adicionado no WordPress 4.4 e aqui está o ticket nº 20451 relevante para obter mais informações.

Observe que o uso do sublinhado na frente da chave meta _testirá ocultá-lo dos campos personalizados metabox na tela de pós-edição.


Ohh, o teste do wp im é 4.3, muito obrigado.
STREEL

0

O jeito que eu faço é via term_id não slug e funciona:

//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);   
}
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.