如何在ASP.NET MVC C#中为jqPlot图表返回多维数组作为JSON

时间:2011-08-03 00:25:04

标签: c# asp.net-mvc json jqplot

json需要采用以下格式:

var data = [
            ['Heavy Industry', 12],['Retail', 9], ['Light Industry', 14], 
            ['Out of home', 16],['Commuting', 7], ['Orientation', 9]
          ];

但是在我的动作方法中,我无法弄清楚如何构造以该格式呈现的json。这就是我所拥有的:

var json = new[] {
                new[] {"Pending", summaryData.Sum(a => (int)a.Pending).ToString() },
                new[] {"Completed", summaryData.Sum(a => (int)a.Completed).ToString()}
            };

        return Json(json, JsonRequestBehavior.AllowGet);

返回以下JSON:

[["Pending","146"],["Completed","914"]]

这是关闭的,除了它们是数字值周围的引号,jqPlot似乎不喜欢它。不幸的是,如果我尝试在其上执行Int32.Parse(...),我会得到一个异常。

任何想法如何做到最好?

由于

1 个答案:

答案 0 :(得分:4)

我猜你在尝试使用Int32.parse时得到的错误就像是“找不到隐式类型数组的最佳类型”。当使用隐式类型数组并且该数组中的值具有不同类型时,编译器不知道要为数组推断的类型。

您可以通过告诉编译器数组的类型来解决错误:

var json = new[] {
                new object[] {"Pending", summaryData.Sum(a => (int)a.Pending) },
                new object[] {"Completed", summaryData.Sum(a => (int)a.Completed) }
            };

这个应该按照你想要的方式序列化数组。

对于jqPlot,数字周围的引号导致问题,因为插件最有可能要求数组中的第二项为Number类型。