如何将此类型代码转换为laravel形式?

时间:2016-01-17 06:39:15

标签: javascript php laravel fullcalendar

if($type == 'fetch')
{
    $events = array();
    $query = mysqli_query($con, "SELECT * FROM calendar");
    while($fetch = mysqli_fetch_array($query,MYSQLI_ASSOC))
    {
    $e = array();
    $e['id'] = $fetch['id'];
    $e['title'] = $fetch['title'];
    $e['start'] = $fetch['startdate'];
    $e['end'] = $fetch['enddate'];

    $allday = ($fetch['allDay'] == "true") ? true : false;
    $e['allDay'] = $allday;

    array_push($events, $e);
    }
    echo json_encode($events);
}

这段代码是关于正常的PHP代码,我想放入laravel控制器,但它不起作用。我的问题是想问一下如何创建这个代码函数并链接到我的数据库。

$.ajax({
        url: 'process.php',
        type: 'POST', // Send post data
        data: 'type=fetch',
        async: false,
        success: function(s){
            json_events = s;
        }
    });

这是我的观看代码,任何人都可以帮助我,并告诉我如何与它链接?所以我可以从我的数据库中获取数据并将其显示在我的fullcalendar上。

编辑后.. 这是我的View代码。     

    $(document).ready(function() {

        $.ajax({
            url: '{{url('events/add')}}',
            type: 'POST', // Send post data
            async: false,
            success: function(s){
                json_events = s;
            }
        });

        $('#calendar').fullCalendar({
            header: {
                left: 'prev,next today',
                center: 'title',
                right: 'month,agendaWeek,agendaDay'
            },

            selectable: true,
            selectHelper: true,
            select: function(start, end) {
                var title = prompt('Event Title:');
                var eventData;
                if (title) {
                    eventData = {
                        title: title,
                        start: start,
                        end: end
                    };
                    $('#calendar').fullCalendar('renderEvent', eventData, true); // stick? = true
                }
                $('#calendar').fullCalendar('unselect');
            },
            editable: true,
            eventLimit: true, // allow "more" link when too many events
        });

    });

</script>

这是我的EventsController

  public function show(Request $request){
        if($request->get('type') == 'fetch'){
            return Events::select(['calendar_id','calendar_title','startdate as start', 'enddate as end'])->get();
        }

    }

1 个答案:

答案 0 :(得分:0)

首先,当您使用Foo::Impl方法&amp;我想你是全球POST中间件,所以每当你请求csrf方法时,你都必须将POST令牌与你的请求一起传递。为此,您可以将csrf令牌添加到元

csrf

&安培;在你的jQuery代码中

<meta name="csrf-token" content="{{ csrf_token() }}">

您可以查看更多详细信息https://laravel.com/docs/5.1/routing#csrf-protection

现在在你的jQuery代码中

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

现在进入你的控制器动作

$.ajax({
    url: 'YOUR_URL_TO_POST',
    type: 'POST', // Send post data
    data: 'type=fetch',
    async: false,
    success: function(s){
        json_events = s;
    }
});

您可以在此处查看https://laravel.com/docs/5.1/eloquent#defining-models如何定义模型。