Javascript 错误的确切位置。无论如何,我已经更新了我的答案并做了进一步的解释。我已经更新了我的代码以符合这一点,但它仍然不起作用,我将把它添加到我的OP中。 public JsonResult GetEvents(double start, double end) {
Javascript 错误的确切位置。无论如何,我已经更新了我的答案并做了进一步的解释。我已经更新了我的代码以符合这一点,但它仍然不起作用,我将把它添加到我的OP中。 public JsonResult GetEvents(double start, double end) {,javascript,jquery,asp.net-mvc,entity-framework,fullcalendar,Javascript,Jquery,Asp.net Mvc,Entity Framework,Fullcalendar,错误的确切位置。无论如何,我已经更新了我的答案并做了进一步的解释。我已经更新了我的代码以符合这一点,但它仍然不起作用,我将把它添加到我的OP中。 public JsonResult GetEvents(double start, double end) { var events = new List<Event>(); var dtstart = ConvertFromUnixTimestamp(start); var dtend = ConvertFrom
错误的确切位置。无论如何,我已经更新了我的答案并做了进一步的解释。我已经更新了我的代码以符合这一点,但它仍然不起作用,我将把它添加到我的OP中。
public JsonResult GetEvents(double start, double end)
{
var events = new List<Event>();
var dtstart = ConvertFromUnixTimestamp(start);
var dtend = ConvertFromUnixTimestamp(end);
DateTime currStart;
DateTime currEnd;
foreach (Event ev in db.Events)
{
currStart = Convert.ToDateTime(ev.StartDate);
currEnd = Convert.ToDateTime(ev.EndDate);
events.Add(new Event()
{
ID = ev.ID,
Title = ev.Title,
StartDate = currStart,
EndDate = currEnd,
AllDay = true,
EventType = ev.EventType,
Hours = ev.Hours
});
}
var rows = events.ToArray();
return Json(rows, JsonRequestBehavior.AllowGet);
}
private static DateTime ConvertFromUnixTimestamp(double timestamp)
{
var origin = new DateTime(1970, 1, 1, 0, 0, 0, 0);
return origin.AddSeconds(timestamp);
}
using System;
using System.ComponentModel.DataAnnotations;
namespace ForecastCalendar.Models
{
public enum EventType
{
BAU,
Project,
AnnualLeave
}
public class Event
{
public int ID { get; set; }
[Required]
[DataType(DataType.Date, ErrorMessage = "Please enter a valid date.")]
[DisplayFormat(DataFormatString = "{0:dd-MM-yyyy}", ApplyFormatInEditMode = true)]
[Display(Name = "Start Date")]
public DateTime StartDate { get; set; }
[Required]
[DataType(DataType.Date, ErrorMessage = "Please enter a valid date.")]
[DisplayFormat(DataFormatString = "{0:dd-MM-yyyy}", ApplyFormatInEditMode = true)]
[Display(Name = "End Date")]
public DateTime EndDate { get; set; }
[Required]
[StringLength(50, ErrorMessage = "Title cannot be longer than 50 characters.")]
[RegularExpression(@"^[a-zA-Z- ]+$", ErrorMessage = "Invalid characters used. A-Z or a-z, '-' and ' ' allowed.")]
[Display(Name = "Title")]
public string Title { get; set; }
[Required]
[EnumDataType(typeof(EventType), ErrorMessage = "Submitted value is not valid.")]
[Display(Name = "Type")]
public EventType? EventType { get; set; }
[Required]
public double Hours { get; set; }
[Required]
public Boolean AllDay { get; set; }
[Timestamp]
public byte[] RowVersion { get; set; }
public virtual Person Person { get; set; }
}
}
@{
ViewBag.Title = "Home Page";
}
@Styles.Render("~/Content/fullcalendar")
@Scripts.Render("~/bundles/jquery")
@Scripts.Render("~/bundles/fullcalendar")
<br />
<div class="container">
<div id="calendar"></div>
</div>
<br />
<script type="text/javascript">
$(document).ready(function () {
$('#calendar').fullCalendar({
header: {
left: 'title',
center: '',
right: 'prev,next today' },
defaultView: 'month',
weekends: false,
editable: false,
events: "/Home/GetEvents/"
});
});
</script>
public JsonResult GetEvents(double start, double end)
{
var fromDate = ConvertFromUnixTimestamp(start);
var toDate = ConvertFromUnixTimestamp(end);
var rslt = db.Events;
List<Event> result = new List<Event>();
foreach (var item in rslt)
{
Event ev = new Event();
ev.ID = item.ID;
ev.Title = item.Title;
ev.Hours = item.Hours;
ev.StartDate = item.StartDate;
ev.EndDate = item.EndDate;
ev.EventType = item.EventType;
ev.AllDay = ev.AllDay;
}
var resultList = result;
var eventList = from e in resultList
select new
{
id = e.ID,
title = e.Title,
start = e.StartDate,
end = e.EndDate,
allDay = e.AllDay
};
var rows = eventList.ToArray();
return Json(rows, JsonRequestBehavior.AllowGet);
}
'start'
public JsonResult GetEvents(double start, double end)
/GetEvents?start=2013-12-01&end=2014-01-12&_=1386054751381
public JsonResult GetEvents(string start, string end)
var dtstart = ConvertFromUnixTimestamp(start);
var dtend = ConvertFromUnixTimestamp(end);