2013-11-04 87 views
0

我有一个JQGrid,我试图加载动态JSON数据(取决于搜索结果)。看来我的问题是我无法以正确的格式获取JSON字符串。JQGrid动态数据加载(JSON)

这里是我的代码:

public ActionResult GridData(string sidx, string sord, int page, int rows) 
    { 

     DataSet data = (DataSet) TempData["temp"]; 


     //var rowdata = GetJson(data.Tables[0]); 
     var jsonData = new 
     { 
      total = data.Tables[0].Rows.Count, 
      page = page, 
      records = data.Tables[0].Rows.Count, 
      rows = GetJson(data.Tables[0]) 
     }; 
     var a = Json(jsonData, JsonRequestBehavior.AllowGet); 
     return a; 

    } 

    public string GetJson(DataTable dt) 
    { 
     System.Web.Script.Serialization.JavaScriptSerializer serializer = new System.Web.Script.Serialization.JavaScriptSerializer(); 
     List<Dictionary<string, object>> rows = new List<Dictionary<string, object>>(); 
     Dictionary<string, object> row = null; 

     foreach (DataRow dr in dt.Rows) 
     { 
      row = new Dictionary<string, object>(); 
      foreach (DataColumn col in dt.Columns) 
      { 
       row.Add(col.ColumnName, dr[col]); 
      } 
      rows.Add(row); 
     } 
     return serializer.Serialize(rows); 
    } 

} 

在我看来:

<script type="text/javascript"> 
jQuery(document).ready(function(){ 
    jQuery("#list").jqGrid({ 
    url:'/Search/GridData/', 
    datatype: 'json', 
    mtype: 'GET', 
    colNames: @Html.Raw(formatColNames()), 
    colModel:@Html.Raw(formatColModel()), 
    pager: jQuery('#pager'), 
    rowNum:10, 
    rowList:[5,10,20,50], 
    viewrecords: true, 
    caption: 'My first grid' 
    }); 
}); 

我怎样才能的形式使用(从SQL服务器我收到回数据一个DataSet)并将其加载到网格中。假设列的格式正确(它们是)。我检查了JSONLint和我的JSON绝对无效,但我不知道如何解决它。

在此先感谢。

回答

1

看来,你正在序列化两次行数据。一旦进入GetJson函数,并再次创建Json结果时。

我会尝试从GetJson函数返回List<Dictionary<string, object>>,并让Json(jsonData)进行序列化。

+0

感谢您的快速解决,我一直盯着代码整天:) –