3

我的代码如下所示:

if ( $query->have_posts() ) {
    $j = 1; 
    while ( $query->have_posts() ) {
        $query->the_post();

        $bcData[] = array(
           'title'=>get_the_title(),
        );

$j++;
    }
echo json_encode($bcData);
} else {
    // no posts found
}

$bcData数组输出(使用print_r):

Array ( 
    [0] => Array ( [title] => Pink Nail Shop 9 ) 
    [1] => Array ( [title] => Pink Nail Shop 8 ) 
)

当我将此数组编码为 json (使用json_encode)时,新创建的 json 看起来像:

[{"title":"Pink Nail Shop 9"},{"title":"Pink Nail Shop 8"}]

虽然我需要这样的json:

[{"shop":{"title":"Pink Nail Shop 9"}},{"shop":{"title":"Pink Nail Shop 8"}}]

希望这是有道理的,因为我一直在努力表达我想要完成的事情。

谢谢!

4

2 回答 2

6
if ( $query->have_posts() )
{
    $bcData = array();
    $j = 1; 
    while ( $query->have_posts() )
    {
        $query->the_post();

        $bcData[] = array(
            'shop' => array(
                'title'=>get_the_title()
            )
        );
        $j++;
    }
    echo json_encode($bcData);
} else {
    // no posts found
}
于 2013-07-24T23:35:59.083 回答
0

你有没有尝试过:

$bcData['shop'][] = array(
   'title'=>get_the_title(),
);
echo json_encode($bcData);
于 2013-07-24T23:37:03.980 回答