0

我希望用 JSON 数据填充我的网格。数据格式如下:

[{
  "SiteId":"1",
  "SiteName":"University of Minessota",
  "SiteStatus":"Fully Operational"
},{
  "SiteId":"2",
  "SiteName":"MSP Airport-Humphrey",
  "SiteStatus":"Settlement Required"
},{
  "SiteId":"3",
  "SiteName":"City Of Minneapolis-Lot C",
  "SiteStatus":"Fully Operational"
},{
  "SiteId":"4",
  "SiteName":"TargetCenter",
  "SiteStatus":"Low Tickets"
},{
  "SiteId":"5",
  "SiteName":"Excel Energy Center",
  "SiteStatus":"Out Of Tickets"
}]

我正在使用我的控制器方法将其传递给视图:

public JsonResult StatusReport()
{
    List<CenterStatus> status = MvcList.Models.CenterStatus.GetStatus();
    return this.Json(status, JsonRequestBehavior.AllowGet);
}

现在在我看来,我需要将此 JSON 数据填充到网格中:

$(document).ready(function () {
    $.ajax({
        type: "POST",
        contentType: "application/json; charset=utf-8",
        url: "CenterStatus/StatusReport.aspx",
        data: "{}",
        dataType: "json",
        success: function (data) {
            for (var i = 0; i < data.d.length; i++) {
                $("#GridView1").append("<tr><td>" + data.d[i].siteID + "</td><td>" + data.d[i].siteName + "</td><td>" + data.d[i].siteStatus + "</td></tr>");    
            }
    },
    error: function (result) {
        alert("Error");
    }
});

但到目前为止,我没有运气实现我的目标。有什么建议么?

4

3 回答 3

3

像这样做。不要append循环调用。将其设置为一个变量并html仅调用该函数一次。

success: function (data) {
                            var row=""
                            $.each(data,function(index,item){
                                row+="<tr><td>"+item.SiteName+"</td></tr>";
                            });
                            $("#GridView1").html(row);
                       },

工作样本:http: //jsfiddle.net/x76LD/1/

于 2012-07-30T16:09:54.947 回答
1

可能你应该使用 justdata而不是data.d在你的成功函数中。

于 2012-07-30T13:01:49.163 回答
0

我猜这url: "CenterStatus/StatusReport.aspx",可能与它有关。正确的 url 应该是:

url: "/CenterStatus/StatusReport"

于 2012-07-30T13:00:36.710 回答