0

我目前正在尝试在我的简单 asp.net 网站中实现出色的 jQuery 插件“周历”(此处)。我已经设置了几个 [WebMethods] 来将数据发送到日历并响应客户端事件(创建事件、修改事件等)。

使用 WebMethods 时,asp.net 的对象自动序列化在发回数据时似乎运行良好,但是当发生相反的情况时,我遇到了问题。

将日历事件发送回服务器的相关 javascript 代码如下:

save: function() {
                    calEvent.id = id;
                    id++;
                    calEvent.start = new Date(startField.val());
                    calEvent.end = new Date(endField.val());
                    calEvent.title = titleField.val();
                    calEvent.body = bodyField.val();

                    $calendar.weekCalendar("removeUnsavedEvents");
                    $calendar.weekCalendar("updateEvent", calEvent);
                    $dialogContent.dialog("close");
                    //SAVE TO DATABASE

                    $.ajax({
                        type: "POST",
                        url: "Tracker.aspx/AddEvent",
                        data: calEvent,
                        contentType: "application/json; charset=utf-8",
                        dataType: "json",
                        success: function(data) {
                            alert("saved");
                        }
                    });

目前我在服务器上只有一个“存根方法”来检查反序列化是否有效:

[WebMthod]    
public static string AddEvent(Event e)
        {
            //save event to database and return something
            return "done";
    }

但是,我在添加事件时遇到以下异常:

无效的 JSON 原语:开始。

在服务器上,我的事件对象组成如下:

[DataContract]
public class Event
{
    [DataMember]
    public int id { get; set; }
    [DataMember]
    public string title { get; set; }
    [DataMember]
    public string body { get; set; }
    [DataMember]
    public string start { get; set; }
    [DataMember]
    public string end { get; set; }
}
4

1 回答 1

0

如下修改对 Web 服务的调用就可以了:

$.ajax({
                        type: "POST",
                        url: "Tracker.aspx/AddEvent",
                        data: '{e : ' + JSON.stringify(calEvent) + '}',
                        contentType: "application/json; charset=utf-8",
                        dataType: "text",
                        success: function(data) {
                            alert("saved");
                        }
                    });

只需使用 JSON.stringify 函数处理发送到服务器的 JSON 格式

于 2009-11-18T11:31:01.840 回答