Jquery Ajax传送和接收DataTable的asp.net代码

本文章讲一下关于jquery ajax传送和接收datatable的asp教程.net代码哦,下面我来举例说明一下ajax传送和接收datatable的实例吧。

asp.net教程代码

简单举例说明

webservices:

[webmethod(true)]
  [scriptmethod(responseformat = responseformat.xml)] 
  public string competitor(string sl_id)
  {
  dataset ds;
  slcompetitor slcompetitor =new slcompetitor();
  ds = slcompetitor.getslcompetitor(int.parse(sl_id));
  return ds.getxml();
  }

js:
 

$$.ajax({
  type: "post",
  url:"../webservices/advquerycarwebservice.asmx/deciderdetai",
  data:"{sl_id:"+sl_id+"}",
  datatype: "xml",
  contenttype: "application/json",
  error:function(data){
  alert("加载时出错,详情:"+data.status+">>>"+data.statustext);
  },  
  success:function(getxml) {
  tabledecider.removechild(tbodydecider);
  $$(getxml).find("table").each(function(i){//xml 目录id
  var name=$$(this).children("stakeholder").text(); //取文本

asp.netx文件

void ihttphandler.processrequest(httpcontext context)
        {
           // context.response.contenttype = "text/json";

            int bids=0;
            int.tryparse(context.request.querystring["bid"].tostring(), out bids);//项目id

            int pid = 0;
            int.tryparse(context.request.querystring["productid"].tostring(),out pid);//产品id

            if (bids != 0 && pid != 0)
            {
                datatable dt = logic.bidaddress.getbidaddresstobidandproductidlist(bids, pid);
                if (dt.rows.count != 0)
                {
                    using (jsonwriter jsont = new jsontextwriter(context.response.output))
                    {
                        jsont.writestartarray();
                        foreach (datarow itemrow in dt.rows)
                        {
                            jsont.writestartobject();

                            jsont.writepropertyname("baid");//table id
                            jsont.writevalue(itemrow["baid"]);

                            jsont.writepropertyname("ps教程address"); //address
                            jsont.writevalue(itemrow["psaddress"]);

                            jsont.writepropertyname("quantity");//数量
                            jsont.writevalue(itemrow["quantity"]);

                            jsont.writepropertyname("unit");//单位
                            jsont.writevalue(itemrow["unit"]);

                            jsont.writepropertyname("note");//备注
                            jsont.writevalue(itemrow["note"]);

                            jsont.writepropertyname("contactman");//联系人
                            jsont.writevalue(itemrow["contactman"]);

                            jsont.writepropertyname("contactmobile");//联系人手机
                            jsont.writevalue(itemrow["contactmobile"]);

                            jsont.writepropertyname("bid");//项目id
                            jsont.writevalue(itemrow["bid"]);

                            jsont.writepropertyname("productid");//产品id
                            jsont.writevalue(itemrow["productid"]);
                            jsont.writeendobject();
                        }
                        jsont.writeendarray();
                    }
                }
                else
                {
                    context.response.output.write("[]");
                }
            }
        }

实例代码二

/// 页面加载时
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void page_load(object sender, eventargs e)
{
//判断是否异步请求
if (request.querystring["ajax"] == "1")
{
processrequest();
}
}
/// <summary>
/// 处理异步请求
/// </summary>
private void processrequest()
{
response.contenttype = "text/html";
string json = request.form["json"];
//反序列化datatable
datatable newdtb = json2dtb(json);
//序列化datatable为json
string back = dtb2json(newdtb);
response.write(back);
response.end();
}
/// <summary>
/// datatable转json
/// </summary>
/// <param name="dtb"></param>
/// <returns></returns>
private string dtb2json(datatable dtb)
{
网页特效serializer jss = new javascriptserializer();
arraylist dic = new arraylist();
foreach (datarow row in dtb.rows)
{
dictionary<string, object> drow = new dictionary<string, object>();
foreach (datacolumn col in dtb.columns)
{
drow.add(col.columnname, row[col.columnname]);
}
dic.add(drow);
}
return jss.serialize(dic);
}
/// <summary>
/// json转datatable
/// </summary>
/// <param name="json"></param>
/// <returns></returns>
private datatable json2dtb(string json)
{
javascriptserializer jss = new javascriptserializer();
arraylist dic = jss.deserialize<arraylist>(json);
datatable dtb = new datatable();
if (dic.count > 0)
{
foreach (dictionary<string, object> drow in dic)
{
if (dtb.columns.count == 0)
{
foreach (string key in drow.keys)
{
dtb.columns.add(key, drow[key].gettype());
}
}
datarow row = dtb.newrow();
foreach (string key in drow.keys)
{
row[key] = drow[key];
}
dtb.rows.add(row);
}
}
return dtb;
}

jquery代码

 

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript" src="js/jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="js/json2.js"></script>
<script type="text/javascript">
//onload
$(function() {
//点击botton1
$("#botton1").click(function() {
var url = "default.aspx?ajax=1";
var dtb = generatedtb();
//序列化对象
var postdata = json.stringify(dtb);
//异步请求
$.post(url, { json: postdata }, function(json) {
createtable(json);
}, "json")
});
});
//生成datatable对象
function generatedtb() {
var dtb = new array();
for (var i = 0; i < 10; i++) {
var row = new object();
row.col1 = i;
row.col2 = i % 2 == 0 ? true : false;
row.col3 = i + "henll"ow";
dtb.push(row);
}
return dtb;
}
//显示json中的数据
function createtable(json) {
var table = $("<table border='1'></table>");
for (var i = 0; i < json.length; i++) {
o1 = json[i];
var row = $("<tr></tr>");
for (key in o1) {
var td = $("<td></td>");
td.text(o1[key].tostring());
td.appendto(row);
}
row.appendto(table);
}
table.appendto($("#back"));
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<input id="botton1" type="button" value="button" />
<div id="back">
</div>
</div>
</form>
</body>
</html>

如果datatable与json类型可以方便的相互转换,都可以迎刃而解了。
优点:1)避免不必要的回传;
2)精简异步请求数据的大小 ;
3)解决数据量较大时,数据发送与接收繁琐的问题。

 

时间: 2024-10-26 15:03:24

Jquery Ajax传送和接收DataTable的asp.net代码的相关文章

Asp.net下使用Jquery Ajax传送和接收DataTable的代码_jquery

服务器再把GridView反构造成DataTable, 再给DataTable增加一行之后,绑定到GridView,然后发回客户端... 能不能简单一点呢? 在使用Ajax数据请求数据,通常都是简单格式,比如String,信息量较少.当然也可以请求回XML,但是XML数据冗余多,取到客户端处理比json麻烦的多. 能不能简单一点呢? 上面这些问题,如果DataTable与JSON类型可以方便的相互转换,都可以迎刃而解了. 优点:1)避免不必要的回传: 2)精简异步请求数据的大小 : 3)解决数据

asp.net中利用Jquery+Ajax+Json实现无刷新分页的实例代码

 本篇文章主要是对asp.net中利用Jquery+Ajax+Json实现无刷新分页的实例代码进行了介绍,需要的朋友可以过来参考下,需要对大家有所帮助  代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="AjaxJson.aspx.cs" Inherits="AjaxJson" %> <!DOCTYPE html PUBLIC &quo

jquery ajax-使用jquery.ajax向后台接收数据

问题描述 使用jquery.ajax向后台接收数据 发送数据是直接用 来发送. ashx中返回了context.Response.ContentType = "text/plain"; context.Response.Write(result); 其中result是StringBuilder. 我想在该页面,用jquery.ajax接收数据, $.ajax({ type: 'get', url: 'test.ashx', dataType: "text", suc

jquery ajax局部加载方法详解(实现代码)_jquery

在jquery中实现ajax加载的方法有很多种,不像以前的js的ajax只有那一种,下面我们介绍jquery ajax实现局部加载方法总结,有需要了解的朋友可参考. 例 $.ajax({ url: "hotelQuery!queryHotelByCity.action", type: "post", dataType: "html", data: "queryHotel.city="+cityobj.value+"&

asp.net中利用Jquery+Ajax+Json实现无刷新分页的实例代码_实用技巧

复制代码 代码如下: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="AjaxJson.aspx.cs" Inherits="AjaxJson" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR

jquery ajax异步请求 接收返回json数据

例子  代码如下 复制代码 $('#send').click(function () {     $.ajax({         type : "GET",         url : "a.php",         dataType : "jsonp",         success : function (data) {             $.each(data.items, function (i, item) {       

JQuery Ajax通过Handler访问外部XML数据的代码_jquery

JQuery的使用非常简单,我们只需要从其官方网站上下载一个脚本文件并引用到页面上即可,然后你就可以在你的脚本代码中任意使用JQuery提供的对象和功能了. 在JQuery中使用Ajax方法异步获取服务器资源非常简单,读者可以参考其官方网站上提供的例子http://api.jquery.com/category/ajax/.当然,作为客户端脚本,JQuery也会遇到跨域访问资源的问题,什么是跨域访问呢?简单来说就是脚本所要访问的资源属于网站外部的资源,脚本所在的位置和资源所在的位置不在同一区域.

Jquery ajax传递复杂参数给WebService的实现代码_jquery

Entity: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Runtime.Serialization; namespace Entity { [DataContract] public class User { [DataMember] public string Name { get; set; } [DataMemb

jQuery Ajax提交表单查询获得数据实例代码_jquery

看一个用jQuery提交表单ajax查询的例子. 基本功能:用户输入一个表单,输入准考证和验证码,验证用户是否输入表单,点击查询提交,然后从服务器得到返回的数据并显示出来. 代码如下: jQuery部分: 复制代码 代码如下: <script language="javascript" type="text/javascript"> $(document).ready(function() { $("#btnSubmit").clic