0

動的な 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 は間違いなく有効ではありませんが、修正方法がわかりません。

前もって感謝します。

4

1 に答える 1

1

行データを 2 回シリアライズしているようです。関数内で 1GetJson回、Json の結果が作成されたときにもう一度。

List<Dictionary<string, object>>GetJson 関数からa を返してJson(jsonData)、シリアル化を行います。

于 2013-11-04T18:49:43.527 に答える