国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Jquery解析json數據詳解

2019-11-20 21:22:48
字體:
來源:轉載
供稿:網友

最近被jquery折磨了一番,倒騰了一個jquery解析json的demo,本demo想實現從asp.net后臺實例化dataSet或者dataTable數據集,將dataSet轉換成json并返回給客戶端,客戶端用jquery getJson方法解析出來并顯示在頁面上。

首先簡單介紹一下getJson方法

Jquery.getJson(url,[data],[callback])

url:發送請求地址。
data:待發送 Key/value 參數。
callback:載入成功時回調函數。

下面是實戰getJson方法

首先 創建一個輔助類,用于將dataset數據集轉換成json字符串

復制代碼 代碼如下:

 public static string DataTableToJson(string jsonName, DataTable dt)
        {
            StringBuilder Json = new StringBuilder();
            Json.Append("{/"" + jsonName + "/":[");
            if (dt.Rows.Count > 0)
            {
                for (int i = 0; i < dt.Rows.Count; i++)
                {
                    Json.Append("{");
                    for (int j = 0; j < dt.Columns.Count; j++)
                    {
                        Json.Append("/"" + dt.Columns[j].ColumnName.ToString() + "/":/"" + dt.Rows[i][j].ToString() + "/"");
                        if (j < dt.Columns.Count - 1)
                        {
                            Json.Append(",");
                        }
                    }
                    Json.Append("}");
                    if (i < dt.Rows.Count - 1)
                    {
                        Json.Append(",");
                    }
                }
            }
            Json.Append("]}");
            return Json.ToString();
        }

此方法是msdn上的一個輔助類方法。

第二步 手動配置創建一個演示Dataset,但在項目中一般都是從數據庫中或者service中獲得數據

復制代碼 代碼如下:

 public static DataSet BindData()
        {
            DataTable dtData = new DataTable();
            dtData.Columns.Add("id");
            dtData.Columns.Add("name");
            dtData.Columns.Add("sex");
            DataRow drData;
            drData = dtData.NewRow();
            drData[0] = 16;
            drData[1] = "zhaoliu";
            drData[2] = "man";
            dtData.Rows.Add(drData);
            drData = dtData.NewRow();
            drData[0] = 19;
            drData[1] = "zhangsan";
            drData[2] = "women";
            dtData.Rows.Add(drData);
            DataSet ds = new DataSet();
            ds.Tables.Add(dtData);
            return ds;
        }

第三步 創建aspx頁面

前臺頁面:兩個button,一個單擊開始解析json數據,另外一個查看json字符串

復制代碼 代碼如下:

<head runat="server">
    <title></title>
    <script language="javascript" type="text/javascript" src="Scripts/jquery-1.4.1.min.js"></script>
    <script language="javascript" type="text/javascript">
        $(function () {
            $("#btn").click(function () {
                $.getJSON("GetJsonDemo.aspx", { Action: "action" },
                 function (data) {
                     var txt = "";
                     $.each(data, function (k, v) { $.each(v, function (m, n) { txt += "id :"+n.id + ";name :" + n.name + ";sex :"+n.sex+"<br/>" }); });
                     $("#txt").html(txt);
                 });

            });
         });

         $(function () {
             $("#btn2").click(function () {
                 $.get("GetJsonDemo.aspx", { Action: "action" },
                 function (data) { $("#txt2").text(data); });
             });

         });
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <input id="btn" type="button" value="paser json" /><br />
        <input id="btn2" type="button" value="watch json string" /><br />
        <label id="txt"></label><br />
         <label id="txt2"></label>
    </div>
    </form>
</body>


后臺頁面:
復制代碼 代碼如下:

 protected void Page_Load(object sender, EventArgs e)
        {
            JsonAjax();
        }
        private void JsonAjax() {
            string action = Request["Action"];
            if (!string.IsNullOrEmpty(action) && action == "action")  //判斷是否通過前臺的點擊事件進來的
            {
                string str = DataTableConvertJson.DataTableToJson("json", Data.BindData().Tables[0]);
                Response.Write(str);
                Response.End();
            }
        }

最后給大家展示一下生成的json格式:

Top of Form

{"json":[{"id":"16","name":"zhaoliu","sex":"man"},{"id":"19","name":"zhangsan","sex":"women"}]}

Bottomof Form

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 罗定市| 和龙市| 丹阳市| 逊克县| 长武县| 沁阳市| 依安县| 桃江县| 延安市| 施甸县| 潜山县| 石城县| 莱阳市| 仪征市| 睢宁县| 电白县| 进贤县| 西峡县| 黄浦区| 长泰县| 福清市| 潼关县| 广平县| 田阳县| 内丘县| 明水县| 永济市| 闽侯县| 阳原县| 康平县| 洞头县| 台北市| 景东| 通道| 香格里拉县| 海口市| 乌兰浩特市| 西贡区| 简阳市| 武定县| 阳西县|