多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > jquery > jquery筆記:用jquery和json從后臺獲得數據集

jquery筆記:用jquery和json從后臺獲得數據集

來源:程序員人生   發布時間:2013-11-01 08:12:56 閱讀次數:3792次

最近正在用ajax無刷新做網站,發現數據很好傳輸,但是數據集不知道怎么獲得,于是,上網查了一些資料來傳輸數據,現在和大家分享一下,不知道的童鞋可以和我一起學習,知道的請指點一二。我選擇的方法是用json 來獲取數據集。

其實Json也就是一種數據的格式,在后臺將數據封轉為一種格式,然后在前臺用相同的方法解析,類似于序列化。json格式主要是由鍵值對組成,它可以表示多個數據。比如

{name:zhangsan,age:12,class:1}

同時json 還可以表示一個數據集,它是又{}和: 來組成的。比如我們需要從數據庫查詢出一張表格,然后將表格傳輸給前臺,但是dataset是不能直接傳輸的,我們需要將dataset數據轉換為json數據,這樣可以方便前臺js解析數據,下面我來寫一下轉換的格式

{Name:表的名稱,Rows:[{SName:姓名,SAge:年齡}{...}{...}]}這是一張表格的數據格式,

{Tables:[{Name:表1的名稱,Rows:[{SName:姓名,SAge:年齡}{...}{...}]}{Name:表2的名稱,Rows:[{SName:姓名,SAge:年齡}{...}{...}]}]}這是多張表的數據格式

下面用一個例子來給大家演示一下數據集得傳輸

首先我們需要一個前臺頁面來獲取數據 studentinfo.html,在這個頁面中我們有一個函數來獲取Json格式的數據,jquery 很好的為我們封裝了一個這樣的函數,JSON.parse();

 <script type="text/javascript">
function getData() {
$("#data").val("");
jQuery.post('../ashx_for_request/getdataset.ashx', {}, function (data) {//data為后臺傳輸過來的數據
var obj = JSON.parse(data); //將后天傳輸的數據轉換為Json格式
$("#data").html("");
$.each(obj.Tables, function (index, table) {//遍歷數據集表格,輸出數據集的內容
//根據不同的表名,顯示不同的字段。得到特定表,table = obj.Tables[0]
var tableName = table.Name;
$.each(table.Rows, function (index, row) {//遍歷數據集表格中的行
$("#data").html($("#data").html() + row.SID + row.SName + row.SAge + row.SClass + row.SSex + row.SGrade + "</br>"); //每行的每一個列的內容 在這里我們用row.colname來獲取每一行每一列的內容
});
});
})
}
</script>

我們用到的是jquery 的post函數來從后臺獲取數據,然后將數據解析,現在我來演示一下后臺的數據格式

private String GetDataSet()
{
System.Data.DataSet ds = new System.Data.DataSet();
//測試用數據
using (System.Data.SqlClient.SqlConnection conn = new System.Data.SqlClient.SqlConnection("server=.;database=Student;uid=sa;pwd=123456"))
{
using (System.Data.SqlClient.SqlCommand com=conn.CreateCommand())
{
com.CommandText = "select * from BaseNews";
System.Data.SqlClient.SqlDataAdapter da = new System.Data.SqlClient.SqlDataAdapter(com);
da.Fill(ds);
}
}
return Dataset2Json(ds);

}

///<summary>
/// dataTable轉換成Json格式
///</summary>
///<param name="dt"></param>
///<returns></returns>
public static string DataTable2Json(System.Data.DataTable dt)
{
StringBuilder jsonBuilder = new StringBuilder();
jsonBuilder.Append("{"Name":"" + dt.TableName + "","Rows");
jsonBuilder.Append("":[");
for (int i = 0; i < dt.Rows.Count; i++)
{
jsonBuilder.Append("{");
for (int j = 0; j < dt.Columns.Count; j++)
{
jsonBuilder.Append(""");
jsonBuilder.Append(dt.Columns[j].ColumnName);
jsonBuilder.Append("":"");
jsonBuilder.Append(dt.Rows[i][j].ToString().Replace(""", """)); //對于特殊字符,還應該進行特別的處理。
jsonBuilder.Append("",");
}
jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
jsonBuilder.Append("},");
}
jsonBuilder.Remove(jsonBuilder.Length - 1, 1);
jsonBuilder.Append("]");
jsonBuilder.Append("}");
return jsonBuilder.ToString();
}

///<summary>
/// DataSet轉換成Json格式
///</summary>
///<param name="ds">DataSet</param>
///<returns></returns>
public static string Dataset2Json(System.Data.DataSet ds)
{
StringBuilder json = new StringBuilder();
json.Append("{"Tables":");
json.Append("[");
foreach (System.Data.DataTable dt in ds.Tables)
{
json.Append(DataTable2Json(dt));
json.Append(",");
}
json.Remove(json.Length - 1, 1);
json.Append("]");
json.Append("}");
return json.ToString();
}

給大家看一下結果

大家可以根據得到的數據給出相應的格式

大家不要以為到這里就完成了哦,Json格式在不同的瀏覽器下會有兼容性問題,這時大家只需下載一個json2的js即可。

(來源:博客園)

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 最近中文字幕免费版在线3 最近中文字幕免费大全8高清 | 最近高清中文字幕大全1 | 久久伊人网站 | 黑人40厘米全进去xxxx猛交 | 中文字幕一区二区三区四区 | 久久久久久久岛国免费播放 | 亚州精品一区二区三区 | jizz成熟丰满中国妇女 | 图片区 日韩 欧美 亚洲 | 欧美一级高清片在线 | 综合色在线观看 | 亚洲综合日韩中文字幕v在线 | 日本免费三区 | 久久优| 16欧美freesex呦交hd | 韩国精品一区二区 | 日本xxxⅹ色视频在线观看网站 | 成人精品国产亚洲欧洲 | 欧美日韩国产另类一区二区三区 | 痴女在线播放免费视频 | 无人日本免费视频 | 欧美日韩一区二区三区四区 | 一级女人18片毛片免费视频 | 欧美在线成人午夜影视 | 国产黄色免费在线观看 | 一二三四在线观看免费中文在线观看 | 国产精品一级视频 | 欧美日韩一区二区视频免费看 | 波多野结衣在线中文字幕 | 中文字幕一二三区乱码老 | 午夜理伦三级播放 | 在线黄视频网站 | 美国一级毛片完整高清 | 日本黄色网址大全 | 白浆都出来了视频国产精品 | 另类小说综合网 | 叼嘿在线观看 | free性a欧美 free性m.freesex欧美 | 免费在线观看黄色网址 | 动漫精品一级毛片动漫 | 三级五月天 |