用jquery和json從后臺(tái)獲得數(shù)據(jù)集的代碼
{name:zhangsan,age:12,class:1}
同時(shí)json 還可以表示一個(gè)數(shù)據(jù)集,它是又{}和: 來(lái)組成的。比如我們需要從數(shù)據(jù)庫(kù)查詢(xún)出一張表格,然后將表格傳輸給前臺(tái),但是dataset是不能直接傳輸?shù)模覀冃枰獙ataset數(shù)據(jù)轉(zhuǎn)換為json數(shù)據(jù),這樣可以方便前臺(tái)js解析數(shù)據(jù),下面我來(lái)寫(xiě)一下轉(zhuǎn)換的格式
{Name:表的名稱(chēng),Rows:[{SName:姓名,SAge:年齡}{...}{...}]}這是一張表格的數(shù)據(jù)格式,
{Tables:[{Name:表1的名稱(chēng),Rows:[{SName:姓名,SAge:年齡}{...}{...}]}{Name:表2的名稱(chēng),Rows:[{SName:姓名,SAge:年齡}{...}{...}]}]}這是多張表的數(shù)據(jù)格式
下面用一個(gè)例子來(lái)給大家演示一下數(shù)據(jù)集得傳輸
首先我們需要一個(gè)前臺(tái)頁(yè)面來(lái)獲取數(shù)據(jù) studentinfo.html,在這個(gè)頁(yè)面中我們有一個(gè)函數(shù)來(lái)獲取Json格式的數(shù)據(jù),jquery 很好的為我們封裝了一個(gè)這樣的函數(shù),JSON.parse();
<script type="text/javascript">
function getData() {
$("#data").val("");
jQuery.post('../ashx_for_request/getdataset.ashx', {}, function (data) {//data為后臺(tái)傳輸過(guò)來(lái)的數(shù)據(jù)
var obj = JSON.parse(data); //將后天傳輸?shù)臄?shù)據(jù)轉(zhuǎn)換為Json格式
$("#data").html("");
$.each(obj.Tables, function (index, table) {//遍歷數(shù)據(jù)集表格,輸出數(shù)據(jù)集的內(nèi)容
//根據(jù)不同的表名,顯示不同的字段。得到特定表,table = obj.Tables[0]
var tableName = table.Name;
$.each(table.Rows, function (index, row) {//遍歷數(shù)據(jù)集表格中的行
$("#data").html($("#data").html() + row.SID + row.SName + row.SAge + row.SClass + row.SSex + row.SGrade + "</br>"); //每行的每一個(gè)列的內(nèi)容 在這里我們用row.colname來(lái)獲取每一行每一列的內(nèi)容
});
});
})
}
</script>
我們用到的是jquery 的post函數(shù)來(lái)從后臺(tái)獲取數(shù)據(jù),然后將數(shù)據(jù)解析,現(xiàn)在我來(lái)演示一下后臺(tái)的數(shù)據(jù)格式
private String GetDataSet()
{
System.Data.DataSet ds = new System.Data.DataSet();
//測(cè)試用數(shù)據(jù)
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轉(zhuǎn)換成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("\"", "\\\"")); //對(duì)于特殊字符,還應(yīng)該進(jìn)行特別的處理。
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轉(zhuǎn)換成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();
}
給大家看一下結(jié)果

大家可以根據(jù)得到的數(shù)據(jù)給出相應(yīng)的格式
大家不要以為到這里就完成了哦,Json格式在不同的瀏覽器下會(huì)有兼容性問(wèn)題,這時(shí)大家只需下載一個(gè)json2的js即可。
- jquery的ajax異步請(qǐng)求接收返回json數(shù)據(jù)實(shí)例
- jQuery Ajax異步處理Json數(shù)據(jù)詳解
- jQuery中使用Ajax獲取JSON格式數(shù)據(jù)示例代碼
- jquery的ajax和getJson跨域獲取json數(shù)據(jù)的實(shí)現(xiàn)方法
- jquery用ajax方式從后臺(tái)獲取json數(shù)據(jù)后如何將內(nèi)容填充到下拉列表
- 詳談 Jquery Ajax異步處理Json數(shù)據(jù).
- JQuery的ajax獲取數(shù)據(jù)后的處理總結(jié)(html,xml,json)
- jquery解析json格式數(shù)據(jù)的方法(對(duì)象、字符串)
- jQuery使用getJSON方法獲取json數(shù)據(jù)完整示例
- jQuery實(shí)現(xiàn)異步獲取json數(shù)據(jù)的2種方式
- jQuery訪問(wèn)json文件中數(shù)據(jù)的方法示例
相關(guān)文章
jquery實(shí)現(xiàn)textarea 高度自適應(yīng)
用jquery實(shí)現(xiàn)的textarea 高度自適應(yīng)代碼。這個(gè)動(dòng)畫(huà)效果比較流暢。適合新手學(xué)習(xí)。非常簡(jiǎn)單實(shí)用,這里推薦給小伙伴們。2015-03-03
jQuery使用contains過(guò)濾器實(shí)現(xiàn)精確匹配方法詳解
這篇文章主要介紹了jQuery使用contains過(guò)濾器實(shí)現(xiàn)精確匹配的方法,結(jié)合實(shí)例形式分析了contains過(guò)濾器的具體使用技巧,需要的朋友可以參考下2016-02-02
jQuery實(shí)現(xiàn)隔行變色的方法分析(對(duì)比原生JS)
這篇文章主要介紹了jQuery實(shí)現(xiàn)隔行變色的方法,結(jié)合實(shí)例形式對(duì)比原生JS實(shí)現(xiàn)隔行變色的相關(guān)技巧,給出了2種jQuery實(shí)現(xiàn)隔行變色的方法,需要的朋友可以參考下2016-11-11
jQuery函數(shù)的第二個(gè)參數(shù)獲取指定上下文中的DOM元素
這篇文章主要介紹了jQuery函數(shù)的第二個(gè)參數(shù)獲取指定上下文中的DOM元素,需要的朋友可以參考下2014-05-05
jquery Mobile入門(mén)—外部鏈接切換示例代碼
內(nèi)部鏈接是通過(guò)在a標(biāo)簽內(nèi)將href屬性值設(shè)為#+id的形式,外鏈則是在a中增加rel屬性,并將屬性值設(shè)為external,感興趣的朋友可以了解下哦2013-01-01
jQuery選擇器之基本過(guò)濾選擇器用法實(shí)例分析
這篇文章主要介紹了jQuery選擇器之基本過(guò)濾選擇器用法,結(jié)合實(shí)例形式分析了jQuery常見(jiàn)的基本過(guò)濾、屬性過(guò)濾、內(nèi)容過(guò)濾、子元素過(guò)濾等相關(guān)操作技巧,需要的朋友可以參考下2019-02-02
jquery調(diào)整表格行tr上下順序?qū)嵗v解
這篇文章主要為大家介紹了jquery調(diào)整表格行tr上下順序?qū)嵗?,具有一定的參考價(jià)值,感興趣的朋友可以參考一下2016-01-01
JQuery boxy插件在IE中邊角圖片不顯示問(wèn)題的解決
這篇文章主要介紹了JQuery boxy插件在IE中邊角圖片不顯示問(wèn)題的解決方法,十分的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。2015-05-05

