• 鄂州重拳治理“散乱污”企业 半年内关停数量比过去两年还多 2019-06-15
  • 【华商侃车NO.192】 亲!楼市火爆,别忘了买车位啊! 2019-06-15
  • 学习领会党的十九大报告需要准确把握的几个重大问题 2019-06-09
  • 飞行员夜间海上实弹射击 导弹全部命中目标 2019-06-07
  • 武警重庆总队举行干部退役仪式 2019-06-06
  • 香港大学发现有效对抗流感病毒的新方法 2019-06-05
  • 一语惊坛(6月15日):人民日报和共和国共同成长。 2019-06-05
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-04
  • 点击天山网 掌握全新疆 2019-06-04
  • 端午小长假各大文化场馆火热迎客 文化游成市民游客假期“心头好” 2019-05-31
  • 肉毒梭菌感染相关新闻 2019-05-31
  • 姚明撰文回忆菜鸟赛季 温暖的回忆感谢弗朗西斯 2019-05-26
  • 遵义师范学院副校长颜永强:长征为军队建设提供三方面宝贵经验 2019-05-23
  • 劲爆福利 昨日中奖名单公布 今日5大箱可乐任意送劲爆福利-等级 2019-05-22
  • 风水神话更危险的事,就是眼瞎,根本分不清谁对谁, 2019-05-22
  • Jquery中文网 南粤风采36选7开奖公告 www.77402m.com
    Jquery中文网 >  jQuery  >  jquery 教程  >  正文 用jquery和json从后台获得数据集的代码

    福建体彩票31选7走势图:用jquery和json从后台获得数据集的代码

    发布时间:2013-06-11   编辑:南粤风采36选7开奖公告 www.77402m.com
    最近正在用ajax无刷新做网站,发现数据很好传输,但是数据集不知道怎么获得,于是,上网查了一些资料来传输数据,现在和大家分享一下,不知道的童鞋可以和我一起学习,知道的请指点一二。我选择的方法是用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();
    }

    南粤风采36选7开奖公告 www.77402m.com 给大家看一下结果

    大家可以根据得到的数据给出相应的格式

    大家不要以为到这里就完成了哦,Json格式在不同的浏览器下会有兼容性问题,这时大家只需下载一个json2的js即可。

    您可能感兴趣的文章:
    用jquery和json从后台获得数据集的代码
    jQuery 中使用JSON的实现代码
    jQuery怎么解析Json字符串(Json格式/Json对象)
    jQuery结合Json提交数据到Webservice,并接收从Webservice返回的Json数据
    jquery ajax跨域解决方法(json方式)
    jquery解析JSON数据示例代码
    Json2Template.js 基于jquery的插件 绑定JavaScript对象到Html模板中
    jQuery 跨域访问问题解决方法
    jquery JSON的解析方式
    jquery eval解析JSON中的注意点介绍

    [关闭]
  • 鄂州重拳治理“散乱污”企业 半年内关停数量比过去两年还多 2019-06-15
  • 【华商侃车NO.192】 亲!楼市火爆,别忘了买车位啊! 2019-06-15
  • 学习领会党的十九大报告需要准确把握的几个重大问题 2019-06-09
  • 飞行员夜间海上实弹射击 导弹全部命中目标 2019-06-07
  • 武警重庆总队举行干部退役仪式 2019-06-06
  • 香港大学发现有效对抗流感病毒的新方法 2019-06-05
  • 一语惊坛(6月15日):人民日报和共和国共同成长。 2019-06-05
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-04
  • 点击天山网 掌握全新疆 2019-06-04
  • 端午小长假各大文化场馆火热迎客 文化游成市民游客假期“心头好” 2019-05-31
  • 肉毒梭菌感染相关新闻 2019-05-31
  • 姚明撰文回忆菜鸟赛季 温暖的回忆感谢弗朗西斯 2019-05-26
  • 遵义师范学院副校长颜永强:长征为军队建设提供三方面宝贵经验 2019-05-23
  • 劲爆福利 昨日中奖名单公布 今日5大箱可乐任意送劲爆福利-等级 2019-05-22
  • 风水神话更危险的事,就是眼瞎,根本分不清谁对谁, 2019-05-22