繁体   English   中英

Fullcalendar JSON事件供稿不适用于PHP

[英]Fullcalendar JSON event feed not working with PHP

由于某种原因,我无法将我的JSON feed(通过php组装)显示在我的Fullcalendar插件上。 JSON是有效的,并且如果我将其硬编码为事件源,则效果很好。 但是,当通过URL提取它时,什么也没有显示! 我知道几个人也遇到过同样的问题,但是要么尚未得到解决,要么他们的解决方案似乎对我不起作用。 非常感谢您提供任何帮助,因为我已经盯着这两天了,不能休息。

这是我的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中,它将起作用! 到底他妈发生了什么? 先感谢您!

我想到了!!! 对于遇到相同问题的任何人,它都与跨域ajax有关。 您可以在以下链接上阅读它: Access-Control-Allow-Origin不允许起源

我只是将此代码添加到了我的php脚本的顶部:

    <?php header('Access-Control-Allow-Origin: http://www.mydomain.com'); ?>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM