何らかの理由で、JSON フィード (php 経由で組み立てられたもの) を Fullcalendar プラグインに表示することができません。JSON は有効であり、イベント ソースとしてハードコーディングするとうまく機能します。しかし、URL 経由でフェッチされている場合は、何も表示されません! 何人かの人々が同じ問題を抱えていることは知っていますが、まだ回答が得られていないか、解決策がうまくいかないようです。私はこれを2日間見つめていて、休憩をとることができないので、これに関する助けは大歓迎です.
これが私のjsです
$(function()
{
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
editable: false,
minTime: 7,
maxTime: 20,
slotMinutes: 15,
eventRender: function (event, element) {
element.find('.fc-event-title').html(event.title);
},
events: {
url: "http://mywebsite.com/js/schedule_feed.php",
data: {locationID: <?=$locationID?>},
type: "POST",
error: function () {
alert('there was an error while fetching events!');
},
},
});
});
そして、ここに私のphpがあります:
<?php
mysql_connect("localhost", "user", "password") or die(mysql_error());
mysql_select_db("mydatabase") or die(mysql_error());
$query = "select schedule.schedule_id, schedule.type, schedule.show, schedule.schedule_date, patients.fname, patients.lname
from schedule
LEFT JOIN patients
ON schedule.patient_id=patients.patient_id
WHERE patients.locationID='".$_POST['locationID']."'";
$res = mysql_query($query) or die(mysql_error());
$events = array();
while ($row = mysql_fetch_assoc($res)) {
$eventsArray['id'] = $row['schedule_id'];
$eventsArray['title'] = ucfirst(strtolower($row['lname'])) . ", " . ucfirst(strtolower($row['fname'])); //. $isNewCustomer;
$eventsArray['start'] = strtotime($row['schedule_date']);
$timestamp = strtotime($row['schedule_date']) + 60*30;
$eventsArray['end'] = $timestamp;
$eventsArray['backgroundColor'] = '#999';
$eventsArray['textColor'] = '#fff';
$eventsArray['url'] = 'http://'.$_SERVER['HTTP_HOST'].'/index.php/schedule/edit_appt/' . $row['schedule_id'];
$eventsArray['allDay'] = false;
$eventsArray['editable'] = false;
$eventsArray['timeFormat'] = 'h(:mm)';
$events[] = $eventsArray;
}
echo json_encode($events);
?>
繰り返しになりますが、php の URL をブラウザーに直接入力すると、有効な JSON が表示されます。その JSON フィードをブラウザーからコピーして、JS に直接ハードコードすると...うまくいきます! 一体何が起こっているのですか?前もって感謝します!