2
現在有很多人遇到同樣的問題,他們的解決方案也沒有奏效。將PHP數組轉換爲Javascript對象console.log後沒有數組
問題
我有一個從REST調用返回的時間列表。除了我希望將它們存儲到JavaScript數組中之外,它們的創建方式與它們應該完全相同。
PHP
function getOpenAppts()
{
global $wpdb;
$final_array = "";
$td = date('m/d/Y');
$datetime = new DateTime('tomorrow');
$tm = $datetime->format('Y-m-d');
$startDate = $td;
$endDate = $tm;
$apptTypeID = "23";
$get_loc = $wpdb->get_results('SELECT provid,id FROM location');
foreach($get_loc as $val){
// call to Athena to get open appointments
$res = getOpenAppointments($val->id, $val->provid, $startDate, $endDate, $apptTypeID);
//print_r($res);
// if we got some appointments back strip any that started before now
if (array_key_exists('totalcount', $res) && $res['appointments'] > 0)
{
$tzStr = "America/Los_Angeles";
$tzObject = new DateTimeZone($tzStr);
$nowDT = new DateTime();
$nowDT->setTimezone($tzObject);
//print_r($nowDT);
//print_r("\n");
$appts = array();
for ($i = 0; $i < count($res['appointments']); $i++)
{
$apptDT = new DateTime($res['appointments'][$i]['date']." ".$res['appointments'][$i]['starttime'], $tzObject);
//print_r($apptDT);
//print_r("\n");
if ($nowDT < $apptDT)
$appts[] = $res['appointments'][$i];
}
}
if (count($appts) > 0)
foreach($appts as $data) {
$final_array[] = $data;
}
else
$res; // something went wrong. return error message
}
echo json_encode($final_array);
}
的header.php
<script>
var times = <?php getOpenAppts(); ?>;
console.log(times); //Will display properly
</script>
但是...當我運行的變量次控制檯(這是使其成爲一個全局變量的頭,我得到這個。
它應該給我確切的同一列表的控制檯。日誌給我
我曾嘗試
我跑:
PARSE.json(times);
沒有效果...
我做在PHP:
無效果......
哪一部分這個過程是不正確的?
這是PHP裏面的函數getOpenAppts()'? –
也許你在其他地方壓倒了它?嘗試改變它的名字是不尋常的,並保持console.log –
剛剛更新了PHP – Cam