ajax传递对象数据集,用jquery和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();

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 + ""); //每行的每一个列的内容 在这里我们用row.colname来获取每一行每一列的内容

});

});

})

}

我们用到的是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);

}

///

/// dataTable转换成Json格式

///

///

///

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();

}

///

/// DataSet转换成Json格式

///

///DataSet

///

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();

}

给大家看一下结果

20111107115241455.png

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是使用jQueryJSON格式数据实现表单的Ajax验证的示例代码: HTML代码: ```html <form id="myForm" action="#" method="post"> <label for="username">用户名:</label> <input type="text" id="username" name="username"><br> <label for="password">密码:</label> <input type="password" id="password" name="password"><br> <input type="submit" value="提交"> </form> ``` jQuery代码: ```javascript $(function() { $('#myForm').submit(function(event) { event.preventDefault(); // 阻止表单的默认提交行为 var formData = $(this).serialize(); // 将表单数据序列化为字符串 $.ajax({ type: 'POST', url: 'validate.php', // 后台处理验证的PHP文件 data: formData, dataType: 'json', // 声明返回的数据类型为JSON success: function(data) { // 请求成功时的回调函数 if (data.status === 'success') { alert('验证通过!'); } else { alert('验证失败:' + data.message); } }, error: function(jqXHR, textStatus, errorThrown) { // 请求失败时的回调函数 alert('请求失败:' + textStatus + ',错误信息:' + errorThrown); } }); }); }); ``` PHP代码: ```php <?php // 模拟验证用户名和密码的函数 function validate($username, $password) { if ($username === 'admin' && $password === '123456') { return true; } else { return false; } } // 获取表单数据 $username = $_POST['username']; $password = $_POST['password']; // 进行验证 if (validate($username, $password)) { $result = array('status' => 'success'); } else { $result = array('status' => 'fail', 'message' => '用户名或密码错误'); } // 返回JSON格式的数据 header('Content-Type: application/json'); echo json_encode($result); ?> ``` 以上代码实现了一个简单的表单验证功能,当用户点击提交按钮时,jQuery会将表单数据通过Ajax方式提交给后台PHP文件进行验证。后台PHP文件根据表单数据进行验证,并将验证结果以JSON格式返回给前端页面,前端页面根据返回数据进行相应的处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值