我有一个JQGrid,我正在尝试加载动态JSON数据(取决于搜索结果)。看来,我的问题是无法以正确的格式获得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'
});
});
如何使用返回的数据(从server以DataSet的形式)并将其加载到网格中。假设列的格式是正确的(它们是)。我检查了JSONLint,我的json绝对无效,但我不知道如何修复它。
提前谢谢。
发布于 2013-11-04 18:49:43
似乎您正在两次序列化行数据。一次在GetJson函数中,另一次在创建Json结果时。
我将尝试从List<Dictionary<string, object>>函数返回一个GetJson,并让Json(jsonData)进行序列化。
https://stackoverflow.com/questions/19774771
复制相似问题