需要帮助弄清楚为什么Fullcalendar没有显示我的事件。 -没有错误显示

时间:2020-06-16 18:07:14

标签: javascript php jquery laravel

我正在使用Laravel7。我按照Fullcalendar网站上的说明进行了搜索,并花了几天的时间试图找出答案。

由于某种原因,我无法拉出或保存数据。我已经尝试过进行转储,就像代码没有触发一样。也许有人可以看到我想念的东西。我正在将CDN用于ajax,jquery和fullcalendar。

这是控制器的代码:

public function index()
{
    if(request()->ajax())
    {

        $start = (!empty($_GET["start"])) ? ($_GET["start"]) : ('');
        $end = (!empty($_GET["end"])) ? ($_GET["end"]) : ('');

        $data = Event::whereDate('start', '>=', $start)->whereDate('end',   '<=', $end)->get(['id','title','start', 'end']);
        return Response::json($data);
    }
    return view('calender');
}


public function create(Request $request)
{
    $insertArr = [ 'title' => $request->title,
        'start' => $request->start,
        'end' => $request->end
    ];
    $event = Event::insert($insertArr);
    return Response::json($event);
}


public function update(Request $request)
{
    $where = array('id' => $request->id);
    $updateArr = ['title' => $request->title,'start' => $request->start, 'end' => $request->end];
    $event  = Event::where($where)->update($updateArr);

    return Response::json($event);
}


public function destroy(Request $request)
{
    $event = Event::where('id',$request->id)->delete();

    return Response::json($event);
}

这是视图中的脚本:

$(document).ready(function () {

    var SITEURL = "{{url('/')}}";
    $.ajaxSetup({
        headers: {
            'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
        }
    });

    var calendar = $('#calendar').fullCalendar({
        editable: true,
        events: SITEURL + "calendar",
        displayEventTime: true,
        editable: true,
        eventRender: function (event, element, view) {
            if (event.allDay === 'true') {
                event.allDay = true;
            } else {
                event.allDay = false;
            }
        },
        selectable: true,
        selectHelper: true,
        select: function (start, end, allDay) {
            var title = prompt('Event Title:');

            if (title) {
                var start = $.fullCalendar.formatDate(start, "Y-MM-DD HH:mm:ss");
                var end = $.fullCalendar.formatDate(end, "Y-MM-DD HH:mm:ss");

                $.ajax({
                    url: SITEURL + "calendar/create",
                    data: 'title=' + title + '&amp;start=' + start + '&amp;end=' + end,
                    type: "POST",
                    success: function (data) {
                        displayMessage("Added Successfully");
                    }
                });
                calendar.fullCalendar('renderEvent',
                    {
                        title: title,
                        start: start,
                        end: end,
                        allDay: allDay
                    },
                    true
                );
            }
            calendar.fullCalendar('unselect');
        },

        eventDrop: function (event, delta) {
            var start = $.fullCalendar.formatDate(event.start, "Y-MM-DD HH:mm:ss");
            var end = $.fullCalendar.formatDate(event.end, "Y-MM-DD HH:mm:ss");
            $.ajax({
                url: SITEURL + 'calendar/update',
                data: 'title=' + event.title + '&amp;start=' + start + '&amp;end=' + end + '&amp;id=' + event.id,
                type: "POST",
                success: function (response) {
                    displayMessage("Updated Successfully");
                }
            });
        },
        eventClick: function (event) {
            var deleteMsg = confirm("Do you really want to delete?");
            if (deleteMsg) {
                $.ajax({
                    type: "POST",
                    url: SITEURL + 'calendar/delete',
                    data: "&amp;id=" + event.id,
                    success: function (response) {
                        if(parseInt(response) > 0) {
                            $('#calendar').fullCalendar('removeEvents', event.id);
                            displayMessage("Deleted Successfully");
                        }
                    }
                });
            }
        }

    });
});

function displayMessage(message) {
    $(".response").html("<div class='success'>"+message+"</div>");
    setInterval(function() { $(".success").fadeOut(); }, 1000);
}

1 个答案:

答案 0 :(得分:0)

最后弄清楚了。感谢大家的回应!一旦开始了新的Laravel项目,我就能查明我所缺少的。

事实证明存在两个问题:

第一个是Fullcalendar.io网站上的文档不是很有帮助。它为您提供了一个起点,但是您自己就可以找出代码中缺少的内容。我的代码需要将其添加到视图中的脚本中:

var calendar = new Calendar(calendarEl, {

事件:“ / myurlfeed.php” });

第二个是我遵循的教程中有一个if语句,如果它是ajax,则执行代码。取出if部分后,它直接访问了代码并能够从数据库中加载。 ew!花费大量时间试图解决这个问题。

相关问题