基于jQuery的ajax功能实现web service的json转化


Posted in Javascript onAugust 29, 2009

不过这篇文章的题目我真不知道该怎么起,如果你因为这个差劲的题目错过这个东西,那真的很可惜。

我在做这个东西之前参考了不少文章:

http://www.roseindia.net/tutorials/json/parse-message-JSON-JS.shtml

http://www.json.org/js.html

http://funkatron.com/site/comments/safely-parsing-json-in-javascript/

http://docs.jquery.com/Ajax/jQuery.getJSON

http://encosia.com/2009/06/29/never-worry-about-asp-net-ajaxs-d-again/

http://encosia.com/2009/04/07/using-complex-types-to-make-calling-services-less-complex/

http://www.isolutionteam.co.uk/json-jquery-ajax-aspnet-and-c-to-get-ajaxed-data-table-rows-passing-multiple-parameters/

第一步需要做的是如何在Server端把一个datatable转坏为自己需要的那种格式:

本来想使用.net的javascriptSerializer来完成的(结合Genirics库的List等),但是后来发现使用NewtonSoft.Json更加灵活,而且扩展性比较好,甚至在网上有找到一些代码能够现成使用。

 

先看看我在Server端如何实现了Data转化:

 

基于jQuery的ajax功能实现web service的json转化

这里不仅能够转换Datatable还有DataSet,以后再扩展JavascriptSerializer的转换功能。需要注意的是转化的最终结果需要是个[]包着的一段字符串.开始我试着使用{}来最终返回json为对象,结果在客户端真的是没有头绪根本就无法转换。最后看到一篇文章介绍,在.net 3.5中你的web Services返回来的结果会自动打包成一个json对象,且名字为d,如:{“d”:***}.所以我只有在服务器端的生成一个array形式的包。

然后我创建了一个数据库表,内容如下:

 

,基于jQuery的ajax功能实现web service的json转化

定义的web方法如下:

 

基于jQuery的ajax功能实现web service的json转化

Serializer方法已经在DNA_JSON中打包好。它是在NewtonSoft.Json的基础转换类基础上扩展的。

 

第二步是客户端的东西:

首先我们需要用到几个js, jQuery.js, json2.js就OK了。

 

基于jQuery的ajax功能实现web service的json转化

上面图所示我们用到了jQuery的ajax和JSON。Parse()转换函数。

还有需要注意的是res.d它是.net 3.5默认为你打包好的json的属性。如果你使用framework2.0就没有这个问题了。

最后是看看如何把这些ojbect组成的array显示在一个table中,代码如下:

<script type="text/javascript"><!-- 
function BuildTable(msg) { 
if ($('#tblResult').length != 0) // remove table if it exists 
{$("#tblResult").remove();} 
var table = '<table class="table.display"><thead> <tr><th>First Name</th> <th>Last Name</th><th>Email</th></thead> <tbody>'; 
for (var i=0;i<=msg.length-1;i++) { 
var row = '<tr>'; 
row += '<td>' + msg[i].UserName+ '</td>'; 
row += '<td>' +msg[i].FirstName+ '</td>'; 
row += '<td>' + msg[i].email + '</td>'; 
row += '</tr>'; 
table += row; 
} 
table += '</tbody></table>'; 
$('#example1').html(table); 
} 
// --></script>

如果还有需要源代码的请留言。接下来我会试着去使用这个方法把一些jQuery的ajax插件介绍给大家,然后把一些datagrid的插件封装成asp.net控件,这样你就不需要使用微软那笨重的datagrid了。
Javascript 相关文章推荐
实现超用户体验 table排序javascript实现代码
Jun 22 Javascript
AngularJS学习笔记(三)数据双向绑定的简单实例
Nov 08 Javascript
javascript中Number的方法小结
Nov 21 Javascript
Angular路由简单学习
Dec 26 Javascript
谈谈JavaScript数组常用方法总结
Jan 24 Javascript
基于JSON数据格式详解
Aug 31 Javascript
实例讲解javascript实现异步图片上传方法
Dec 05 Javascript
react配合antd组件实现的管理系统示例代码
Apr 24 Javascript
vue集成百度UEditor富文本编辑器使用教程
Sep 21 Javascript
基于JS开发微信网页录音功能的实例代码
Apr 30 Javascript
vue+django实现一对一聊天功能的实例代码
Jul 17 Javascript
jQuery操作选中select下拉框的值代码实例
Feb 07 jQuery
用户注册常用javascript代码
Aug 29 #Javascript
csdn 博客中实现运行代码功能实现
Aug 29 #Javascript
js 分栏效果实现代码
Aug 29 #Javascript
javascript 简练的几个函数
Aug 29 #Javascript
关于IE、Firefox、Opera页面呈现异同 写脚本很痛苦
Aug 28 #Javascript
jQuery一步一步实现跨浏览器的可编辑表格,支持IE、Firefox、Safari、Chrome、Opera
Aug 28 #Javascript
javascript 遍历验证所有文本框的值
Aug 27 #Javascript
You might like
基于PHP开发中的安全防范知识详解
2013/06/06 PHP
php多种形式发送邮件(mail qmail邮件系统 phpmailer类)
2014/01/22 PHP
php5.3以后的版本连接sqlserver2000的方法
2014/07/28 PHP
php curl请求信息和返回信息设置代码实例
2015/04/27 PHP
php官方微信接口大全(微信支付、微信红包、微信摇一摇、微信小店)
2015/12/21 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
JavaScript实现表格排序方法
2013/06/14 Javascript
Js参数值中含有单引号或双引号问题的解决方法
2013/11/06 Javascript
js 实现菜单左右滚动显示示例介绍
2013/11/21 Javascript
基于jquery实现发送文章到手机的代码
2014/12/26 Javascript
JavaScript移除数组内重复元素的方法
2015/03/18 Javascript
jquery树形菜单效果的简单实例
2016/06/06 Javascript
Javascript中apply、call、bind的巧妙使用
2016/08/18 Javascript
WEB前端实现裁剪上传图片功能
2016/10/17 Javascript
有关JS中的0,null,undefined,[],{},'''''''',false之间的关系
2017/02/14 Javascript
vue基于element的区间选择组件
2018/09/07 Javascript
微信小程序使用map组件实现获取定位城市天气或者指定城市天气数据功能
2019/01/22 Javascript
nodejs+express最简易的连接数据库的方法
2020/12/23 NodeJs
python中lambda函数 list comprehension 和 zip函数使用指南
2014/09/28 Python
Python中的面向对象编程详解(上)
2015/04/13 Python
python实现bucket排序算法实例分析
2015/05/04 Python
Python使用修饰器执行函数的参数检查功能示例
2017/09/26 Python
Python for循环生成列表的实例
2018/06/15 Python
在Qt中正确的设置窗体的背景图片的几种方法总结
2019/06/19 Python
Numpy将二维数组添加到空数组的实现
2019/12/05 Python
python连接mongodb数据库操作数据示例
2020/11/30 Python
CSS3 input框的实现代码类似Google登录的动画效果
2020/08/04 HTML / CSS
德国W家官网,可直邮中国的母婴商城:Windeln.de
2021/03/03 全球购物
会话Bean的种类
2013/11/07 面试题
ktv收银员岗位职责
2013/12/16 职场文书
尽职尽责村干部自我鉴定
2014/01/23 职场文书
意外死亡赔偿协议书
2014/10/14 职场文书
学前班学生评语
2014/12/29 职场文书
检讨书格式
2015/05/07 职场文书
修辞手法有哪些?
2019/08/29 职场文书
vue.js 使用原生js实现轮播图
2022/04/26 Vue.js