【发布时间】:2020-03-05 15:23:47
【问题描述】:
我正在使用全日历 JavaScript 库开发日历。我已经准备好前端,但我不确定如何更新数据库中的事件数据,在它被删除到日历之后。我对 JavaScript 很陌生,我提到了一些类似的问题,但没有得到我想要的东西。
这是我的代码:
**index.php**
<link href='https://unpkg.com/@fullcalendar/core@4.4.0/main.min.css' rel='stylesheet' />
<link href='https://unpkg.com/@fullcalendar/daygrid@4.4.0/main.min.css' rel='stylesheet' />
<link href='https://unpkg.com/@fullcalendar/timegrid@4.4.0/main.min.css' rel='stylesheet' />
<script src='https://unpkg.com/@fullcalendar/core@4.4.0/main.min.js'></script>
<script src='https://unpkg.com/@fullcalendar/interaction@4.4.0/main.min.js'></script>
<script src='https://unpkg.com/@fullcalendar/daygrid@4.4.0/main.min.js'></script>
<script src='https://unpkg.com/@fullcalendar/timegrid@4.4.0/main.min.js'></script>
<div id='external-events'>
<p>
<strong>Draggable Events</strong>
</p>
<div class='fc-event'>My Event 1</div>
<div class='fc-event'>My Event 2</div>
<div class='fc-event'>My Event 3</div>
<div class='fc-event'>My Event 4</div>
<div class='fc-event'>My Event 5</div>
<p>
<input type='checkbox' id='drop-remove' />
<label for='drop-remove'>remove after drop</label>
</p>
</div>
<div id='calendar-container'>
<div id='calendar'></div>
</div>
** main.js**
document.addEventListener('DOMContentLoaded', function() {
var Calendar = FullCalendar.Calendar;
var Draggable = FullCalendarInteraction.Draggable;
var containerEl = document.getElementById('external-events');
var calendarEl = document.getElementById('calendar');
var checkbox = document.getElementById('drop-remove');
new Draggable(containerEl, {
itemSelector: '.fc-event',
eventData: function(eventEl) {
return {
title: eventEl.innerText
};
}
});
var calendar = new Calendar(calendarEl, {
plugins: [ 'interaction', 'dayGrid', 'timeGrid' ],
header: {
left: 'prev,next today',
center: 'title',
right: 'dayGridMonth,timeGridWeek,timeGridDay'
},
editable: true,
droppable: true,
drop: function(info) {
if (checkbox.checked) {
info.draggedEl.parentNode.removeChild(info.draggedEl);
}
},
});
calendar.render();
});
**add_event.php**
require 'database.php';
echo $_POST['title'];
$title = $_POST['title'];
$start = $_POST['start'];
$end = $_POST['end'];
$conn = DB::databaseConnection();
$conn->beginTransaction();
$sqlInsert = "INSERT INTO Events (title, start, [end]) VALUES (:title, :start, :end)";
$stmt = $conn->prepare($sqlInsert);
$stmt->bindParam(':title', $title);
$stmt->bindParam(':start', $start);
$stmt->bindParam(':end', $end);
if ($stmt->execute()) {
$conn->commit();
return true;
} else {
$conn->rollback();
return false;
}
这是我提到的密码的链接:https://fullcalendar.io/docs/external-dragging-demo 我只是不确定如何让 javascript 链接到插入函数。因此,当事件被删除时,它应该保存在数据库中。
【问题讨论】:
-
您需要在 fullCalendar 中处理
eventReceive回调。这将为您提供来自已删除项目的关联事件数据。然后,您可以使用 AJAX 将该数据发送到 add_event.php。见fullcalendar.io/docs/eventReceive -
P.S. 警告:您的代码容易受到 SQL 注入攻击。您应该使用参数化查询来帮助防止攻击者通过使用恶意输入值来破坏您的数据库。 bobby-tables.com 给出了风险解释,以及一些如何使用 PHP 安全地编写查询的示例。 切勿将未经处理的数据直接插入您的 SQL 中。以您现在编写代码的方式,有人可以轻松窃取、错误更改甚至删除您的数据。 (您使用了准备好的语句,但也没有使用参数,它没有提供任何保护!)
-
嘿,你能解释一下我如何处理事件接收吗?我得到了 ajax 部分,但在此之前需要处理 eventreceive 吗?
-
感谢 sql 部分。那我应该做bindparam吗?
-
是的,你绝对必须做 bindparam
标签: javascript php fullcalendar fullcalendar-4