WP_Query resulta na forma de resultados da Rest API

6

Esta é uma matriz de resultados de postagens simples.

$query = new WP_Query( array( 'post_type' => 'post' ) );
$posts = $query->posts; // returns simple array of data

Existe uma maneira de obter os resultados de wp-json / wp / v2 / posts /? _ embed sem fazer uma solicitação extra ao servidor para puxar o json e, em seguida, decodificar para o array php?

Procurando por algo assim:

$posts = $query->rest_posts(); // for example ??
    
por Janiis 17.01.2018 / 12:17

3 respostas

4

Acho que podemos simplificá-lo com:

$request  = new WP_REST_Request( 'GET', '/wp/v2/posts' );
$response = rest_do_request( $request );
$data     = rest_get_server()->response_to_data( $response, true );

usando rest_do_request() .

    
por birgire 17.01.2018 / 16:25
0

$ query = new WP_Query (array ('post_type' = > 'post'));

$ posts = $ query- > posts; // retorna uma matriz simples de dados

Existe uma maneira de obter os resultados de wp-json / wp / v2 / posts /? _ embed sem fazer uma solicitação extra ao servidor para puxar o json e, em seguida, decodificar para o array php?

Procurando por algo assim:

$ posts = $ query- > rest_posts (); // por exemplo ??

    
por Dharmishtha Patel 19.01.2018 / 07:01
0

Depois de mergulhar no código-fonte, acabamos com essa solução. Funciona para mim, pode ser útil para os outros também.

function get_rest_items_query($post_type, $posts_per_page, $orderby = 'date', $order = 'desc') {

    $result = array();
    $args = array( 'post_type' => $post_type, 'posts_per_page' => $posts_per_page, 'orderby' => $orderby, 'order' => $order );
    $posts = get_posts($args);

    $ids = implode(',', wp_list_pluck($posts, 'ID'));

    // request
    $restRequest = new WP_REST_Request('GET', '/wp/v2/' . $post_type  );
    $restRequest->set_param('include', $ids);
    // response
    $response = rest_do_request( $restRequest );
    // _embed
    $rest = rest_get_server()->response_to_data( $response, true );

    $result['posts'] = $rest;

    return $result;
}
    
por Janiis 17.01.2018 / 16:07

Tags