1

これは私のコードです。データの取得と解析には問題なく機能しますが、イベントを表示できません。考えられる理由を教えてください。

ここではcallback(event)が機能していないようです。

 events: function(callback)
                {
                    $.ajax({
                        type: "POST",
                        url: "WebService.asmx/hello",
                        data: "{}",
                        contentType: "application/json; charset=utf-8",
                        dataType: "json",
                        success: function(data)
                        {
                            var evnt = [];
                            $(data.d).find('event').each(function()
                            {

                                evnt.push({
//                                    title: $(this).attr('title'),
//                                    start: $(this).attr('start'),
                                //                                    end: $(this).attr('end')
                                       title: 'Events1',
                                       start: '2010-04-01',
                                       end: '2010-04-10'
                                });

                            });
                              alert('called end');
                            callback(evnt);

                        },
                        error: OnError
                    });
                }
4

3 に答える 3

0

この問題があり、.asmx ファイルでクラスまたはメソッドをどのように装飾しても、結果として XML を取得し続けました。最後に、標準の .aspx ページを作成するのに役立つリンクを見つけました。.aspx ファイルは次のようになります。

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="ScheduledEvents.aspx.cs" Inherits="ScheduledEvents" %>

そして、私の .aspx.cs ファイルは次のとおりです。

public partial class ScheduledEvents : System.Web.UI.Page
{
 protected override void Render(HtmlTextWriter writer)  
 {
   List<Event> itemList = new List<Event>();
   for (int i = 0; i < 5; ++i)
   {
        Event newEvent = new Event();
        newEvent.id = i;
        newEvent.className = "";
        newEvent.title = "Test";
        newEvent.start = (((int)DateTime.Now.AddDays(i).ToUniversalTime().Subtract(Event.rootTime).TotalSeconds)).ToString();
        newEvent.end = (((int)DateTime.Now.AddDays(i).AddMinutes(60).ToUniversalTime().Subtract(Event.rootTime).TotalSeconds)).ToString();
        newEvent.url = "http://www.google.com";
        newEvent.allDay = false;
        itemList.Add(newEvent);
   }
   Response.Clear();
   Response.ContentType = "application/json";
   Response.Write(new JavaScriptSerializer().Serialize(itemList.ToArray()));  
 }
}

Event クラスの構成は推測できますが、次のようになります。

public class Event
{
  public static readonly DateTime rootTime = DateTime.Parse("1970-01-01 00:00:00");
  public int id = default(int);
  public string className = string.Empty;
  public string title = string.Empty;
  public string start = string.Empty;
  public string end = string.Empty;
  public string url = string.Empty;
  public bool allDay = false;
}

Full Calendar は 1970 年 1 月 1 日からの秒数を使用するため、「rootTime」を使用します。また、startDate と endDate は int としてキャストされて小数点以下の桁数が削減されますが、これはフル カレンダーでは好ましくありません。

于 2010-10-01T12:54:52.683 に答える
0

私は信じてstartおり、end日付オブジェクトである必要があります

title: 'Events1',
start: new Date(2010, 4, 1),
end: new Date(2010, 4, 10)

ドキュメントを参照してください: http://arshaw.com/fullcalendar/docs/event_data/Event_Object/

于 2010-04-19T19:38:58.763 に答える
0

Web サービスを使用して ASP.NET で FullCalendar を動作させる方法の例を作成しました。

http://jake1164.blogspot.com/2010/06/jquery-fullcalendar-and-aspnet.html

于 2010-07-21T19:48:07.447 に答える