麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > JavaScript > 正文

Jquery解析json數(shù)據(jù)詳解

2019-11-20 21:22:48
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

最近被jquery折磨了一番,倒騰了一個(gè)jquery解析json的demo,本demo想實(shí)現(xiàn)從asp.net后臺(tái)實(shí)例化dataSet或者dataTable數(shù)據(jù)集,將dataSet轉(zhuǎn)換成json并返回給客戶端,客戶端用jquery getJson方法解析出來(lái)并顯示在頁(yè)面上。

首先簡(jiǎn)單介紹一下getJson方法

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

url:發(fā)送請(qǐng)求地址。
data:待發(fā)送 Key/value 參數(shù)。
callback:載入成功時(shí)回調(diào)函數(shù)。

下面是實(shí)戰(zhàn)getJson方法

首先 創(chuàng)建一個(gè)輔助類,用于將dataset數(shù)據(jù)集轉(zhuǎn)換成json字符串

復(fù)制代碼 代碼如下:

 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上的一個(gè)輔助類方法。

第二步 手動(dòng)配置創(chuàng)建一個(gè)演示Dataset,但在項(xiàng)目中一般都是從數(shù)據(jù)庫(kù)中或者service中獲得數(shù)據(jù)

復(fù)制代碼 代碼如下:

 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;
        }

第三步 創(chuàng)建aspx頁(yè)面

前臺(tái)頁(yè)面:兩個(gè)button,一個(gè)單擊開(kāi)始解析json數(shù)據(jù),另外一個(gè)查看json字符串

復(fù)制代碼 代碼如下:

<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>


后臺(tái)頁(yè)面:
復(fù)制代碼 代碼如下:

 protected void Page_Load(object sender, EventArgs e)
        {
            JsonAjax();
        }
        private void JsonAjax() {
            string action = Request["Action"];
            if (!string.IsNullOrEmpty(action) && action == "action")  //判斷是否通過(guò)前臺(tái)的點(diǎn)擊事件進(jìn)來(lái)的
            {
                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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 视频国产一区二区 | 欧美成人精品一区二区 | 日韩视频一区二区 | 久久99国产精品久久 | 国产羞羞视频免费在线观看 | 国产精品一区二区手机在线观看 | 一区二区国产在线 | 亚洲一区二区三区四区精品 | 国产成人精品无人区一区 | 国产自在线 | 黄色a级片视频 | 成年人国产视频 | 精品一区二区中文字幕 | 久久国产精品久久精品国产演员表 | 性猛aa久久久 | 亚洲成人福利在线观看 | 久久久www成人免费精品 | 欧美成人黄色小视频 | 亚洲国产高清自拍 | 国产在线观看91一区二区三区 | 999插插插 | 日产精品久久久一区二区开放时间 | 欧美a∨一区二区三区久久黄 | 九九热在线观看视频 | 免费久久久久久久 | 在线播放h | 精选久久| av在线免费看片 | 一边吃奶一边插下面 | 久久精品片 | 最新中文字幕日本 | 久久久www成人免费毛片 | 99极品视频 | 亚洲3p激情在线观看 | 久久精片 | 久久久久久久久亚洲精品 | 免费一级a毛片免费观看 | 日本在线播放一区二区三区 | 午夜精品成人一区二区 | 毛片在线视频在线播放 | 亚洲一二区精品 |