0

我在通过 Web 服务将 KendoUI 图表绑定到远程数据库时遇到了一些问题。

这是我的代码:

    $("#chart").kendoChart({
    theme: $(document).data("kendoSkin") || "default",
    dataSource: {
        transport: {
            read: {
                url: "/WebServices/WebFunctions.asmx/RetrieveProjectCountByBMP",
                dataType: "json"
            }
        },
        schema: {
            model: {
                fields: {
                    Code: { type: "string" },
                    Count: { type: "number" }
                }
            }
        },
        sort: {
            field: "Code",
            dir: "asc"
        }
    },
    title: {
        text: "Project Count by BMP"
    },
    seriesDefaults: {
        type: "column"
    },
    series: [{
        field: "Count",
        name: "Project Count"
    }],
    categoryAxis: {
        field: "Code"
    },
    tooltip: {
        visible: true,
        format: "{0:N0}"
    }
});

这是网络服务代码:

<WebMethod(EnableSession:=True)> _
Public Function RetrieveProjectCountByBMP() As Object
    Dim returnData = (From p As Project In Project.RetrieveAll() _
                     Join cs As ClaimScope In ClaimScope.RetrieveAll() On p.ProjectId Equals cs.ProjectId _
                     Join b As BMP In BMP.RetrieveAll On cs.BMPId Equals b.BMPId _
                     Where (p.ProjectMilestoneId = 17 Or p.ProjectMilestoneId = 18 Or p.ProjectMilestoneId = 19) _
                     And p.FiscalyearId = 5 _
                     Select b.Code, p.ProjectId).GroupBy( _
                        Function(bmpCode) bmpCode.Code _
                        , Function(proj) proj.ProjectId _
                        , Function(bmpCode, projects) New With {.Code = bmpCode, .Count = projects.Count()})

    Dim serializedReturnData As JavaScriptSerializer = New JavaScriptSerializer(returnData)

    Return serializedReturnData.Serialize(serializedReturnData)

    Return serializedReturnData
End Function

我已经验证我的网络服务返回了一个完整的数据集。问题是当我运行代码时,图表没有被填充。事件日志中没有错误消息,也没有触发任何事件。

我能找到的唯一问题是 web 服务返回带有前导引号的数据,如下所示:

"[{"代码":"1301","计数":239},{"代码":"1401","计数":178},{"代码":"1001","计数":33}] "

当我将从 Web 服务返回的数据复制到 .json 文件中并将图表绑定到该文件时,它工作正常。但是,我必须删除前导引号和尾随引号才能使其正常工作。

如何让我的网络服务以正确的 JSON 格式返回我的数据?

谢谢。

4

1 回答 1

0

Maybe this way:

Return Mid(serializedReturnData, 2, Len(serializedReturnData) - 2)
于 2012-03-14T03:29:52.740 回答