fullCalendarとMySQLを使用して、MySQLバックアップイベントインターフェイスを作成しようとしています。私はfullCalendarのドキュメントの例を操作しようとし、データベースからイベントフィードを正常に作成しました。fullCalendarイベントをMySQLに送信する
私は現在、イベントID、タイトル、および開始時刻をデータベースに送信するeventDrop
コールを作成しようとしています。私はここで全体callendarページ用のJavaScriptで、eventDrop
コールを作成するために、以前のquestionからのコードを使用:
$(document).ready(function() {
/* initialize the external events
-----------------------------------------------------------------*/
$('#external-events div.external-event').each(function() {
// create an Event Object (http://arshaw.com/fullcalendar/docs/event_data/Event_Object/)
// it doesn't need to have a start or end
var eventObject = {
title: $.trim($(this).text()) // use the element's text as the event title
};
// store the Event Object in the DOM element so we can get to it later
$(this).data('eventObject', eventObject);
// make the event draggable using jQuery UI
$(this).draggable({
zIndex: 999,
revert: true, // will cause the event to go back to its
revertDuration: 0 // original position after the drag
});
});
/* initialize the calendar
-----------------------------------------------------------------*/
$('#calendar').fullCalendar({
header: {
left: 'prev,next today',
center: 'title',
right: 'month,agendaWeek,agendaDay'
},
editable: true,
droppable: true, // this allows things to be dropped onto the calendar !!!
drop: function(date, allDay) { // this function is called when something is dropped
// retrieve the dropped element's stored Event Object
var originalEventObject = $(this).data('eventObject');
// we need to copy it, so that multiple events don't have a reference to the same object
var copiedEventObject = $.extend({}, originalEventObject);
// assign it the date that was reported
copiedEventObject.start = date;
copiedEventObject.allDay = allDay;
// render the event on the calendar
// the last `true` argument determines if the event "sticks" (http://arshaw.com/fullcalendar/docs/event_rendering/renderEvent/)
$('#calendar').fullCalendar('renderEvent', copiedEventObject, true);
// if so, remove the element from the "Draggable Events" list
$(this).remove();
},
// events from mysql database
events: "/json-events.php",
// submit to database
eventDrop: function(calEvent, jsEvent, view) {
var method = 'POST';
var path = 'submit.php';
var params = new Array();
params['id'] = calEvent.id;
params['start'] = calEvent.start;
params['end'] = calEvent.end;
params['title'] = calEvent.title;
post_to_url(path, params, method);
}
});
});
私はPOSTデータを受信し、最後にデータベースに挿入して望んだPHPファイル開始時間+ 15分(以下の回答の後に編集)に等しい時間:
<?php
mysql_connect("") or die(mysql_error());
mysql_select_db("") or die(mysql_error());
$id = $_POST["id"];
$title = $_POST["title"];
$start = $_POST["start"];
$end = date(Y-m-d T H:i:s , strtotime($start)+900);
$query = "INSERT INTO `events` VALUES (`$id`, `$title`, `$start`, `$end`, ``)";
mysql_query($query);
print $query;
?>
データベースにイベントデータが受信されていません。
回答ありがとうございます。私は理解し、直接値で私の提出ファイルをテストし、運がないとデータベースをチェックし始めたと思います。私はPHPファイルを次のように変更しました: '$ id = $ _POST [" id "]; $ title = $ _POST ["title"]; $ start = $ _POST ["start"]; $ end = date(Y-m-d T H:i:s、strtotime($ start)+900); $ query = "INSERT INTO'イベント 'VALUE(' $ id'、 '$ title'、' $ start'、 '$ end'、' '); mysql_query($ query); print $ query 'URLを介して変数を直接渡すと内部サーバーエラーが発生しますか? – SlartyBartfast