我使用的是一个JQuery图表插件,它使用多维数组
获取数据点 var line1 = [['23-May-2008', 1578.55], ['20-Jun-2008', 566.5],
['25-Jul-2008', 480.88], ['22-Aug-2008', 509.84]];
如何从c#返回如上格式的数据?我已经尝试生成一个匹配输出的字符串,但它不起作用......
StringBuilder sb = new StringBuilder();
foreach (Stats s in perfData)
{
sb.Append("['" + String.Format("{0:MM-dd-yyyy}", p.Date) + "'], " + "[" + p.Value +"],");
}
string data = sb.ToString();
data += data.TrimEnd(new[] { ',' });
data = "[" + data + "]";
答案 0 :(得分:4)
您可以使用任何JSON序列化程序( DataContractJsonSerializer , JavaScriptSerializer )将您的对象转换为javascript格式。但我个人更喜欢Json.Net。
List<object[]> array2D = new List<object[]>() {
new object[] { DateTime.Now.AddDays(-1000), 1578.55 },
new object[] { DateTime.Now.AddDays(-2000), 566.5 },
new object[] { DateTime.Now.AddDays(-3000), 480.88 },
new object[] { DateTime.Now.AddDays(-4000), 509.84 }
};
string jsonstr = JsonConvert.SerializeObject(array2D,new MyDateTimeConvertor());
public class MyDateTimeConvertor : Newtonsoft.Json.Converters.DateTimeConverterBase
{
public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
{
throw new Exception("Not implemented yet");
}
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
{
writer.WriteValue(((DateTime)value).ToString(@"dd-MMM-yyy"));
}
}
并且输出是有效的javascript对象
[["04-May-2009",1578.55],["08-Aug-2006",566.5],["12-Nov-2003",480.88],["15-Feb-2001",509.84]]
答案 1 :(得分:3)
使用JavaScriptSerializer
程序集中的System.Web.Extensions
:
var data = perfData.Select(p =>
new object[] { String.Format("{0:MM-dd-yyyy}", p.Date), p.Value });
var serializer = new JavaScriptSerializer();
var json = serializer.Serialize(data);
答案 2 :(得分:0)
我认为您应该尝试使用JSON帮助程序(JavaScript Object Notation)进行这种操作。我找到了这个链接,希望这有助于http://weblogs.asp.net/hajan/archive/2010/07/23/javascriptserializer-dictionary-to-json-serialization-and-deserialization.aspx
答案 3 :(得分:0)
这不是有效的JSON,所以要检查你的插件是否正在使用JSON,如果是,那么在C#中使用JSONserializer。
foreach (Stats s in perfData)
{
sb.Append("['" + String.Format("{0:MM-dd-yyyy}", p.Date) +","+ p.Value +"],");
}
string data = sb.ToString();
data += data.TrimEnd(new[] { ',' });
data = "[" + data + "]";