3

我正在将 jquery fullcalendar 集成到我的应用程序中。这是我正在使用的代码:

在 index.aspx 中:

<script type="text/javascript">
   $(document).ready(function() {
       $('#calendar').fullCalendar({
           events: "/Scheduler/CalendarData"
       });
   });  
</script>

<div id="calendar">
</div>

这是调度程序/日历数据的代码:

public ActionResult CalendarData()
    {

        IList<CalendarDTO> tasksList = new List<CalendarDTO>();

        tasksList.Add(new CalendarDTO
        {
            id = 1,
            title = "Google search",
            start = ToUnixTimespan(DateTime.Now),
            end = ToUnixTimespan(DateTime.Now.AddHours(4)),
            url = "www.google.com"
        });
        tasksList.Add(new CalendarDTO
        {
            id = 1,
            title = "Bing search",
            start = ToUnixTimespan(DateTime.Now.AddDays(1)),
            end = ToUnixTimespan(DateTime.Now.AddDays(1).AddHours(4)),
            url = "www.bing.com"
        });

        return Json(tasksList,JsonRequestBehavior.AllowGet);
    }

    private long ToUnixTimespan(DateTime date)
    {
        TimeSpan tspan = date.ToUniversalTime().Subtract(
        new DateTime(1970, 1, 1, 0, 0, 0));

        return (long)Math.Truncate(tspan.TotalSeconds);
    }

    public ActionResult Index()
    {
        return View("Index");
    }

我在 site.master 的 head 标记中也有以下代码:

<asp:ContentPlaceHolder ID="ContentPlaceHolder1" runat="server" />
<link href="<%= Url.Content("~/Content/jquery-ui-1.7.2.custom.css") %>" rel="stylesheet" type="text/css" />
<link href="~Perspectiva/Content/Site.css" rel="stylesheet" type="text/css" />
<link href="~Perspectiva/Content/fullcalendar.css" rel="stylesheet" type="text/css" />
<script src="~Perspectiva/Scripts/jquery-1.4.2.js" type="text/javascript"></script>
<script src="~Perspectiva/Scripts/fullcalendar.js" type="text/javascript"></script>
<script src="/Scripts/MicrosoftAjax.debug.js" type="text/javascript"></script>
<script src="/Scripts/MicrosoftMvcAjax.debug.js" type="text/javascript"></script>

我所做的一切都是从http://szahariev.blogspot.com/2009/08/jquery-fullcalendar-and-aspnet-mvc.html复制而来的

导航到 /scheduler/calendardata 时,我会收到保存 json 数据的提示,这些数据正是我在 CalendarData 函数中创建的内容。

为了正确呈现页面,我需要做什么?

提前致谢,

伊兰

更新: 根据 Rune 和 Franci 的评论,我添加了一个名为 CalendarData.aspx 的视图,它与 index.aspx 相同。结果:

  • 导航到 /scheduler/calendardata 仍然会给我保存文件对话框。
  • 导航到 /scheduler/index 我在 Visual Studio 中收到以下运行时错误:Microsoft JScript 运行时错误:预期对象。VS 突出显示脚本标签中的 $(document).ready(function()...) 代码。
4

6 回答 6

1

尝试使用 JSONResult 而不是 ActionResult。

public JSonResult CalendarData()
{
    IList<CalendarDTO> tasksList = new List<CalendarDTO>();

    tasksList.Add(new CalendarDTO
    {
        id = 1,
        title = "Google search",
        start = ToUnixTimespan(DateTime.Now),
        end = ToUnixTimespan(DateTime.Now.AddHours(4)),
        url = "www.google.com"
    });
    tasksList.Add(new CalendarDTO
    {
        id = 1,
        title = "Bing search",
        start = ToUnixTimespan(DateTime.Now.AddDays(1)),
        end = ToUnixTimespan(DateTime.Now.AddDays(1).AddHours(4)),
        url = "www.bing.com"
    });

    return Json(tasksList, JsonRequestBehavior.AllowGet);
}
于 2010-07-19T19:15:14.317 回答
0

您需要导航到映射到返回 Index.aspx 的操作的 URL,而不是映射到 CalendarData() 的 URL。我认为这将类似于“/调度程序”。当您转到“/scheduler/calenderData”时,服务器会将 Json 数据直接返回给浏览器。

于 2010-05-26T20:05:03.857 回答
0

在不让最终用户经历疯狂的事情的情况下,我让它工作的唯一方法是在返回时将内容类型更改为“text/html”。

我已经尝试了上面的所有建议,以及其他一些建议。

哎呀,我什至试过这个

于 2013-03-18T15:04:55.507 回答
0

如果您/scheduler/calendarData在浏览器中导航到,浏览器会收到带有Content-Type: application/json. 有些浏览器不知道如何显示这样的内容类型,所以他们让你将内容保存为本地文件,这样你就可以在另一个程序中查看它。

您应该导航到您的浏览器/scheduler/index,它会返回一个人类可读的结果,所有浏览器都可以呈现该结果(具有Content-Type: text/html)。

如果您想查看返回的内容以CalendarData进行调试,您有两种选择:

  • 使用能理解的浏览器Content-Type: application/json
  • 使用像Fiddler这样的工具,它允许您检查 HTTP 流量
于 2010-05-26T20:18:01.397 回答
0

我有同样的问题,我错过了返回视图的基本 ActionResult 开始......?我在想这是更深层次的东西......但这里是检查解决我的问题的基本事项;

在我的家庭控制器中;

public ActionResult Index()
    {
        ViewData["Message"] = "Whatever!!! just work!";

        return View();
    }

在 Global 中,我还必须将我的 maproutes 重新修复为默认值,因为我在尝试修复它时正在轮换到 GetData 操作:

routes.MapRoute(
    "Default",                                              // Route name
    "{controller}/{action}/{id}",                           // URL with parameters
    new { controller = "Home", action = "Index", id = "" }  // Parameter defaults
);
于 2010-07-09T06:08:18.037 回答
0

尝试使用 JSONResult 而不是 ActionResult。

于 2010-07-03T00:09:00.660 回答