将json数据渲染到asp.net mvc中的网格中

时间:2012-07-30 12:56:34

标签: javascript jquery ajax asp.net-mvc json

我希望用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");
    }
});

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

3 个答案:

答案 0 :(得分: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/

答案 1 :(得分:1)

您可以在成功函数中使用data代替data.d

答案 2 :(得分:0)

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

url: "/CenterStatus/StatusReport"