我花了太多的时间试图弄清楚如何使用JS和JSON从我的C#应用程序中提取所需的所有值。当我只使用简单的结构(比如数组)时,它工作得很好,但我需要能够在运行时增加列表。
现在,我能想到的最好的方法就是使用递增的键值创建一个字典,并将其他3个值作为类对象。但是,这似乎会使我的C#应用程序崩溃。
做这件事最好的方法是什么?
相关C#代码:
public class ChatData
{
string userName;
string message;
System.DateTime timestamp;
public ChatData(string name, string msg)
{
userName = name;
message = msg;
timestamp = System.DateTime.Now;
}
}
else if (string.Equals(request, "getchat"))
{
//string since = Request.Query.since;
Dictionary<int, ChatData> data = new Dictionary<int, ChatData>();
data.Add(1, new ChatData("bob", "hey guys"));
data.Add(2, new ChatData("david", "hey you"));
data.Add(3, new ChatData("jill", "wait what"));
return Response.AsJson(data);
}相关Javascript:
function getChatData()
{
$.getJSON(dataSource + "?req=getchat", "", function (data)
{
//$.each(data, function(key, val)
//{
//addChatEntry(key, val);
//})
});
}发布于 2011-09-04 21:18:37
为什么不简单地使用类型化列表呢?此外,您还需要一个默认构造函数来序列化/反序列化它。请注意我是如何修改您的类以使用属性的。注意,正如@rudolf_franek提到的,如果需要能够链接到ChatData类,则可以向该类添加ID属性。
public class ChatData
{
public ChatData()
{
TimeStamp = DateTime.Now;
}
public int ID { get; set; }
public string Who { get; set; }
public string Said { get; set; }
public DateTime TimeStamp { get; set; }
}
...
var data = new List<ChatData>
{
new ChatData { ID = 1, Who = "bob", Said = "hey guys" },
...
};
return Response.AsJson( data );发布于 2011-09-04 21:16:03
您还没有解释什么是Response.AsJson以及它是如何实现的,但是如果它使用JavaScriptSerializer,您将得到以下异常:
未处理的异常: System.ArgumentException:字典的序列化/反序列化不支持类型“System.Collections.Generic。Dictionary`2[System.Int32,Mcorlib. Version=4.0.0.0,Culture=neutral,PublicKeyToken=b77a5c561934e089,ChatData,Test,Version=1.0.0.0,Culture=neutral,PublicKeyToken=null]”。
这是非常不言而喻的。如果您打算JSON序列化此结构,则不能使用整数作为键。另外,因为您的ChatData类不再具有默认/无参数构造函数,所以无法将JSON字符串反序列化为此类(但我猜您还不需要这样做)。
因此,您的问题的一个可能的解决方案是使用:
Dictionary<string, ChatData> data = new Dictionary<string, ChatData>();
data.Add("1", new ChatData("bob", "hey guys"));
data.Add("2", new ChatData("david", "hey you"));
data.Add("3", new ChatData("jill", "wait what"));正如我在previous question中所解释的,字典不会被序列化为javascript数组,所以你不能循环遍历它们。
长话短说,定义一个类:
public class ChatData
{
public string Username { get; set; }
public string Message { get; set; }
public DateTime TimeStamp { get; set; }
}然后填充这个类的数组:
var data = new[]
{
new ChatData { Username = "bob", Message = "hey guys" },
new ChatData { Username = "david", Message = "hey you" },
new ChatData { Username = "jill", Message = "wait what" },
};
return Response.AsJson(data);并最终消费:
$.getJSON(dataSource, { req: 'getchat' }, function (data) {
$.each(data, function(index, element) {
// do something with element.Username and element.Message here, like
$('body').append(
$('<div/>', {
html: 'user: ' + element.Username + ', message:' + element.Message
})
);
});
});https://stackoverflow.com/questions/7299423
复制相似问题