Я создаю простой PHP для вывода данных в диаграммы javascript apexcharts. Чтобы сделать вывод apexcharts пригодным для использования, мне нужно указать значения x и y графиков в формате JSON. ниже кода я написал для вывода ожидаемого JSON.
$data_arr = array();
global $mysqli_conn;
$result = $mysqli_conn->query("sql");
$sql_out = array();
$sql_out = $result->fetch_all(MYSQLI_ASSOC);
$num_rows = mysqli_num_rows($result);
if ($num_rows < 1){
echo "zero";
}else{
foreach($sql_out as $item) {
$data_arr['x'][] = $item['time'];
$data_arr['y'][] = $item['status_code'];
}
}
$test_arr = array(
array(
"name"=>"lock",
"data"=>array($data_arr),
)
);
echo json_encode($test_arr);
мой ожидаемый вывод json, как показано ниже
[
{
"name": "lock",
"data": [
{
"x": "2019-05-30 07:53:07",
"y": "1470"
},
{
"x": "2019-05-29 07:52:27",
"y": "1932"
}
]
}
]
Но когда я запрашиваю данные из своего кода, я получаю что-то вроде этого
[
{
"name": "lock",
"data": [
{
"x": [
"2019-05-30 07:53:07",
"2019-05-29 07:52:27",
"2019-05-26 15:46:56",
"2019-05-25 07:39:24"
],
"y": [
"1470",
"1932",
"1940",
"1470"
]
}
]
}
]
Как я могу создать ожидаемый результат JSON из кода PHP?
Вы создаете их в отдельном пространстве. Когда вы объявляете и нажимаете их, поместите их в один контейнер:
foreach ($sql_out as $item) {
$data_arr[] = array(
'x' => $item['time'],
'y' => $item['status_code']
);
}
Когда вы делаете это:
$data_arr['x'][] = $item['time'];
$data_arr['y'][] = $item['status_code'];
Они находятся в отдельных контейнерах, контейнерах x и y, поэтому вы получаете неправильный формат, такой как тот, который вы показали.
Когда вы объявляете их как:
$data_arr[] = array(
'x' => $item['time'],
'y' => $item['status_code']
);
Вы в основном говорите, что нужно отправлять все подпартии, но вместе.
Спасибо. это работает отлично и дает ожидаемый результат.