加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 业界 > 正文

jquery条记:用jquery和json从靠山得到数据集

发布时间:2018-08-26 03:18:48 所属栏目:业界 来源:站长网
导读:最近正在用ajax无革新做网站,发明数据很好传输,可是数据集不知道怎么得到,于是,上网查了一些资料来传输数据,此刻和各人分享一下,不知道的童鞋可以和我一路进修,知道的请指点一二。我选择的要领是用json 来获取数据集。 着实Json也就是一种数据的格

最近正在用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();
}

给各人看一下功效

jquery条记:用jquery和json从靠山得到数据集

各人可以按照获得的数据给出响应的名目

各人不要觉得到这里就完成了哦,Json名目在差异的赏识器下会有兼容性题目,这时各人只需下载一个json2的js即可。

(来历:博客园)

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读