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


Posted in Javascript onSeptember 12, 2010

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

<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 + "he\nll\"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>

后台代码:
/// <summary>
/// 页面加载时 
/// </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) 
{ 
JavaScriptSerializer 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; 
}

再附一个下载文件,觉得有用的可以下载看看
json.zip
Javascript 相关文章推荐
Ucren Virtual Desktop V2.0
Nov 07 Javascript
使用jQuery实现dropdownlist的联动效果(sharepoint 2007)
Mar 30 Javascript
js 数值转换为3位逗号分隔的示例代码
Feb 19 Javascript
jQuery实现的简洁下拉菜单导航效果代码
Aug 26 Javascript
js鼠标点击按钮切换图片-图片自动切换-点击左右按钮切换特效代码
Sep 02 Javascript
深入理解JavaScript中的call、apply、bind方法的区别
May 30 Javascript
Bootstrap企业网站实战项目4
Oct 14 Javascript
深入理解JavaScript中的尾调用(Tail Call)
Feb 07 Javascript
详解vue2 $watch要注意的问题
Sep 08 Javascript
puppeteer库入门初探
Jan 09 Javascript
javascript中innerHTML 获取或替换html内容的实现代码
Mar 17 Javascript
uni-app使用countdown插件实现倒计时
Nov 01 Javascript
Asp.net下利用Jquery Ajax实现用户注册检测(验证用户名是否存)
Sep 12 #Javascript
jQuery EasyUI 的EasyLoader功能介绍
Sep 12 #Javascript
jQuery UI 应用不同Theme的办法
Sep 12 #Javascript
基于jquery的表格排序
Sep 11 #Javascript
javascript多种数据类型表格排序代码分析
Sep 11 #Javascript
javascript 触发HTML元素绑定的函数
Sep 11 #Javascript
Js组件的一些写法
Sep 10 #Javascript
You might like
PHP中实现进程间通讯
2006/10/09 PHP
NOD32 v2.70.32 简体中文封装版 提供下载了
2007/02/27 PHP
discuz authcode 经典php加密解密函数解析
2020/07/12 PHP
PHP开发环境配置(MySQL数据库安装图文教程)
2010/04/28 PHP
fgetcvs在linux的问题
2012/01/15 PHP
PHP编码转换函数 自动转换字符集支持数组转换
2012/12/16 PHP
php set_time_limit()函数的使用详解
2013/06/05 PHP
在PHP中使用X-SendFile头让文件下载更快
2014/06/01 PHP
PHPMailer发送邮件
2016/12/28 PHP
PHP扩展mcrypt实现的AES加密功能示例
2019/01/29 PHP
php源码的使用方法讲解
2019/09/26 PHP
jquery cookie插件代码类
2009/05/26 Javascript
javascript放大镜效果的简单实现
2013/12/09 Javascript
JQ图片文件上传之前预览功能的简单实例(分享)
2017/11/12 Javascript
Element Table的row-class-name无效与动态高亮显示选中行背景色
2018/11/30 Javascript
layer弹出层扩展主题的方法
2019/09/11 Javascript
原生js实现密码强度验证功能
2020/03/18 Javascript
python3 pillow生成简单验证码图片的示例
2017/09/19 Python
Windows下将Python文件打包成.EXE可执行文件的方法
2018/08/03 Python
python绘制热力图heatmap
2020/03/23 Python
Python实现一个带权无回置随机抽选函数的方法
2019/07/24 Python
Python函数装饰器原理与用法详解
2019/08/16 Python
Python面向对象之Web静态服务器
2019/09/03 Python
Python requests及aiohttp速度对比代码实例
2020/07/16 Python
幼儿教师寄语集锦
2014/04/03 职场文书
企业法人授权委托书
2014/04/03 职场文书
合作协议书怎么写
2014/04/18 职场文书
10的分与合教学反思
2014/04/30 职场文书
公司优秀员工获奖感言
2014/08/14 职场文书
党性观念心得体会
2014/09/03 职场文书
打架赔偿协议书范本
2014/10/26 职场文书
工作态度不好检讨书
2015/05/06 职场文书
大学毕业晚会开场白
2015/05/29 职场文书
毕业生就业推荐表自我鉴定
2019/06/20 职场文书
最美劳动诗,致敬所有的劳动者!
2019/07/12 职场文书
2019最新版劳务派遣管理制度
2019/08/16 职场文书