.NET2.0环境下的Ajax选型和应用(提供Demo源码下载)

主题:.NET2.0环境下的Ajax选型和应用

研究需要解决的问题:

1 Ajax 应用框架的选型及其性能对比

2 如何应用 Ajax

3 应用 Ajax 过程中应该着重注意的问题

研究者: Jimmy.Ke

时间: 2006-11-13

一 Demo说明

Ajax Demo Web Site 是一个完整的 .NET Website ,其中包含 5 个 ASPX 页面及其对应的 CS 文件。

为了方便对比, Demo 中使用了三种 Ajax 应用方式:

一是使用微软提供的 Atlas 应用框架,二是使用 Ajax.NET Professional 开源框架,三是使用针对 Ajax 的单纯的 Javascript 包 Prototype 。三者对应的关联文件如下表所示:














































应用方式

文件名称

描述

 

Default.aspx

首页导航,列出四个 Demo 页面的链接

Atlas

AtlasDemo.aspx

使用 Atlas 实现 Product 的 CRUD 功能,通过 UpdatePanel 完成无刷新操作。

 

AjaxPro

AjaxProDemo.aspx

使用 Ajax.NET Pro 实现 Product 的 CRUD 功能,编辑、删除操作返回 true/false 的结果,通过 .NET DataGrid 控件实现页面数据列表的呈现( HTML )。

 

 

AjaxProDemoSecond.aspx

使用 Ajax.NET Pro 实现 Product 的 CRUD 功能,编辑、删除操作返回所有的 Product 列表,通过 .NET DataGrid 控件实现页面数据列表的呈现( HTML )。

 

Prototype

PrototypeDemo.aspx

使用 Prototype 实现 Product 的 CRUD 功能,编辑、删除操作返回所有的 Product 列表, Client 和 Server 的数据以 JSON 格式传输。

 

 

 

Product.cs

Product 实体类

二 研究结论


1 Ajax 应用框架选型

Ajax 应用的核心是通过 XMLHttpRequest 对象向 Server 提交 Client 的请求,同步或者异步的获取 Server 返回的 Response 信息,而 Client 和 Server 之前数据传递的方式可以采用 Text 、 XML 或者 JSON 格式。

Demo 中使用到的 Prototype 、 Ajax.NET Pro 、 Atlas Beta2 代表了目前 Ajax 应用的三种主要方式:

Prototype 是目前应用比较广泛的最底层的远程调用工具包,其通常使用自己的 API 封装 XMLHttpRequest 对象,使得调用 XMLHttpRequest 更加简单直观。在 XMLHttpRequest 之前,我们通常使用内嵌的 IFRAME 来实现无刷新页面发送 http 请求的效果。因此,这些远程调用包必须支持那些不支持 XMLHttpRequest 的浏览器,以提高浏览器兼容性。类似的工具还比如 DOJO 。这类工具在应用过程中需要设定自己的 URL 和参数,并且编写相应的 callback 函数来处理 Server 返回的 Response 结果。

在 PrototypeDemo.aspx 中,我们通过 Ajax.Request 向服务器提交请求,在 callback 函数中实现对 Server 的 Response 结果的处理和显示。当然,每个请求的 URL 参数是不同的。

Ajax.NET Pro 则是一种基于基于代理实现的 Ajax 框架,其允许 Client 的 Javascript 直接与 Server 的类实现一一映射,使 Client 的 Javascript 可以通过他们直接访问 Server 的类对象及其 API ,其访问方式类似 RPC ,直接调用相应的 API 完成业务操作,仍然需要编写相应的 callback 函数处理 Server 返回的 Response 结果。

在 AjaxProDemo.aspx.cs 中,我们通过在方法头部添加 [AjaxPro.AjaxMethod] 标注,在 Page_Load 中将类以 AjaxPro.Utility.RegisterTypeForAjax(typeof(AjaxProDemo)) 的形式予以注册, 这样就可以在 Client 直接调用。

Atlas 则是基于组件的应用方式,其允许使用拖拉的方式在 IDE 的设计视图中快速创建包含 Ajax 功能的组件,并且能够最大程度的利用 .NET 本身提供的 DataGrid 、 Button 等 UI 控件。这些组件提供了快速开发 Ajax 应用的另一捷径,开发过程不需要编写 callback 函数。

就目前而言, Atlas 能够利用最多的是 UpdatePanel 控件,通过其实现页面的无刷新或者部分刷新。

2 Ajax 框架性能及开发效率对比

A 、数据流量

Demo 中的四个 Sample 都实现了针对 Product 的简单 CRUD 功能。这里我们使用 Fiddler HTTP Debugger 来测试整个操作过程中 Client 和 Server 交互的数据量。

加载 Product List
























请求 URL

数据流量

说明

Prototype

PrototypeServerResponse.aspx

?action=listProduct

Request Count:      1

Bytes Sent:     380

Bytes Received: 2,150

获取 Product 列表,以 JSON 的格式返回,客户端使用 Javascript 脚本处理呈现。

Ajax.NET Pro ( Second

ajaxpro/AjaxProDemoSecond,

App_Web_qgwv3twq.ashx

Request Count:      1

Bytes Sent:     493

Bytes Received: 1,392

获取 Product 列表,以 HTML 的格式返回,客户端直接呈现。

Atlas

AtlasDemo.aspx

Request Count:      1

Bytes Sent:     827

Bytes Received: 6,391

获取 Product 列表, Server 完成 DataGrid 数据源绑定呈现。

删除 Product
























请求

数据流量

说明

Prototype

PrototypeServerResponse.aspx

?action=deleteProduct&productId=1

Request Count:      1

Bytes Sent:     446

Bytes Received: 1,891

传送 ProductId ,完成删除操作,并获取 Product 列表到 Client 端呈现。

Ajax.NET Pro ( Second

ajaxpro/AjaxProDemoSecond,

App_Web_qgwv3twq.ashx

Request Count:      1

Bytes Sent:     504

Bytes Received: 1,300

调用远程 RPC 接口,完成删除操作,并获取 Product 列表的 HTML 在 Client 端呈现。

Atlas

AtlasDemo.aspx

Request Count:      1

Bytes Sent:     2,287

Bytes Received: 5,913

触发 Server 端的 Action 事件,完成删除操作,需要 Postback 整个页面。

获取 Product Info
























请求

数据流量

说明

Prototype

PrototypeServerResponse.aspx

?action=getProduct&productId=8

Request Count:      1

Bytes Sent:     443

Bytes Received: 403

传送 ProductId ,获取 JSON 格式的 Product 信息, Client 端完成解析并呈现。

Ajax.NET Pro ( Second

ajaxpro/AjaxProDemoSecond,

App_Web_qgwv3twq.ashx

Request Count:      1

Bytes Sent:     506

Bytes Received: 284

调用 RPC 接口,获取 Text 格式的 Product 信息, Client 端完成解析并呈现。

Altas

AtlasDemo.aspx

Request Count:      1

Bytes Sent:     2,185

Bytes Received: 6,275

触发 Server 端的 Action 事件,获取 Product 信息,需要 Postback 整个页面。

编辑 Product
























请求

数据流量

说明

Prototype

PrototypeServerResponse.aspx

?action=updateProduct&productId=8

&productName=Sony&manufacturer=China

Request Count:      1

Bytes Sent:     482

Bytes Received: 1,877

传送 ProductId 等参数,完成保存操作,并获取 Product 列表。

Ajax.NET Pro ( Second

ajaxpro/AjaxProDemoSecond,

App_Web_qgwv3twq.ashx

Request Count:      1

Bytes Sent:     549

Bytes Received: 1,284

调用远程 PPC 接口,完成保存操作,并获取 HTML 格式的 Product 列表。

Atlas

AtlasDemo.aspx

Request Count:      1

Bytes Sent:     2,218

Bytes Received: 5,913

触发 Server 端的 Action 事件,完成保存操作,需要 Postback 整个页面。

增加 Product
























请求

数据流量

说明

Prototype

PrototypeServerResponse.aspx

?action=addProduct&productName=Sony

&manufacturer=China

Request Count:      1

Bytes Sent:     467

Bytes Received: 2,050

传送 ProductName 等参数,完成增加操作,并获取 JSON 格式的 Product 列表。

Ajax.NET Pro

ajaxpro/AjaxProDemoSecond,

App_Web_qgwv3twq.ashx

Request Count:      1

Bytes Sent:     529

Bytes Received: 1,364

调用远程 RPC 接口,完成增加操作,并获取 HTML 格式的 Product 列表。

Atlas

AtlasDemo.aspx

Request Count:      1

Bytes Sent:     2,249

Bytes Received: 6,533

触发 Server 端的 Action 事件,完成增加操作,需要 Postback 整个页面。

结论:

从上述对比表中可以看到, Atlas 在实现无刷新的显示过程中,还是需要 Postback 整个页面,只是这个过程是以异步方式进行处理的;当 Server 端完成响应后, Atlas 客户端根据页面的时候完成 partial-page 的更新。所以对于任何局部页面的操作,页面的 Postback 还是需要的。如果页面的数据量特别大, Atlas 将会导致效率的降低。

Prototype 和 Ajax.NET Pro 的数据量差别不大。

B 、开发效率

Atlas 紧密的和 .NET 的控件结合在一起。如果使用 Atlas ,则可以最大程度的复用 .NET 的控件,比如数据显示控件。

使用 Prototype ,需要在 Javascript 代码中提交 Request 请求到 Server ,并且编写相应的 callback 函数完成 Response 结果的解析和呈现。

使用 Ajax.NET Pro ,可以直接调用 Server 的类的方法(远程 RPC ),不过还是需要编写相应的 callback 函数完成 Response 结果的解析和呈现。

C 、 Server 端返回的数据格式

Ajax.NET Pro 中提供了序列化成 JSON 格式的接口和方法。

Server 端返回的数据格式,可以是简单的 Text ,也可以是 XML 文档,或者通过 Ajax.NET Pro 序列化成 JSON 格式。

三 使用Ajax需要注意的问题

暂缓。

四 参考材料

Micorsoft Fiddler HTTP Debugger : http://www.fiddlertool.com/fiddler/

Prototype : http://prototype.conio.net/

Ajax.NET Pro : http://www.ajaxpro.info/

Atlas Beter 2 : http://ajax.asp.net/default.aspx?tabid=47

点击这里下载Demo源码
点击这里下载Demo Web Site

(0)

相关推荐

  • .NET2.0环境下的Ajax选型和应用(提供Demo源码下载)

    主题:.NET2.0环境下的Ajax选型和应用 研究需要解决的问题: 1 Ajax 应用框架的选型及其性能对比 2 如何应用 Ajax 3 应用 Ajax 过程中应该着重注意的问题 研究者: Jimmy.Ke 时间: 2006-11-13 一 Demo说明 Ajax Demo Web Site 是一个完整的 .NET Website ,其中包含 5 个 ASPX 页面及其对应的 CS 文件. 为了方便对比, Demo 中使用了三种 Ajax 应用方式: 一是使用微软提供的 Atlas 应用框架,

  • Zend Framework入门之环境配置及第一个Hello World示例(附demo源码下载)

    本文实例讲述了Zend Framework入门之环境配置及第一个Hello World程序.分享给大家供大家参考,具体如下: 第一步:确认你的PHP环境: 1.请PHPer确认你的PHP版本是否在5.2.0以上..如果不是的话..请更新到5.2.0,否则.Zend Framework 好像用不了..我自己有试过. 遇到过这样的问题..所以请你们自己测试一下..PHP源码最新版下载地址为:http://www.php.net/downloads.php. 2.你的PHP环境配置好了之后,请打开ph

  • ASP.NET2.0使用Enter Key作为默认提交问题分析(附源码)

    本文实例分析了ASP.NET2.0使用Enter Key作为默认提交的方法.分享给大家供大家参考,具体如下: 网页开发中最烦人的事情之一就是为表单处理"Enter key" ,"Enter key"已经成为用户提交表单的偏好.虽然我们为用户提供了提交按钮,但是最简单也是最直接的方式仍然是:输入文字,然后回车完成提交 ASP.NET 2.0中为此提供了很好的解决方法.只需要将"defaultbutton"属性指定到想要引发事件的按钮控件的ID上就可

  • Ajax in action 英文版配书源码 下载

    Ajax in action英文版的配书源码,找了N久,终于找到了. 近期有时间的话放在网上做个demo 本地下载

  • jQuery实现的纵向下拉菜单实例详解【附demo源码下载】

    本文实例讲述了jQuery实现的纵向下拉菜单.分享给大家供大家参考,具体如下: 当我们浏览网页和使用word编辑一下文字的时候,我们都能看见横向下拉的身影,有了横向菜单,我们能对整个界面进行更好的布局,达到我们想要的效果,那么这些横向菜单式如何用代码实现的,当我们浏览或使用的时候她又是如何呈现在我们面前的,学习了JQuery之后,小编渐渐看到她美丽的容颜,接下来,小编主要讲解如何通过jquery实现纵向下拉菜单. 第一步,我们来编写html的代码,如下所示: <!DOCTYPE html PUB

  • AngularJS入门教程之与服务器(Ajax)交互操作示例【附完整demo源码下载】

    本文实例讲述了AngularJS与服务器Ajax交互操作.分享给大家供大家参考,具体如下: AngularJS从Web服务器请求资源都是通过Ajax来完成,所有的操作封装在$http服务中,$http服务是只能接收一个参数的函数,这个参数是一个对象,用来完成HTTP请求的一些配置,函数返回一个对象,具有success和error两个方法. 用法如下: $http({method:'post',url:'loginAction.do' }).success(function(data,status

  • JS图片延迟加载插件LazyImgv1.0用法分析【附demo源码下载】

    本文实例讲述了JS图片延迟加载插件LazyImgv1.0用法.分享给大家供大家参考,具体如下: 注:LazyImg 必须定义lazy-data属性,属性值是src的图片路径 引入JS文件: <script type="text/javascript" src="js/lazyImg.v1.0.js"></script> 默认情况下: 在IMG中满足以任何一个条件,都会加载图片: 1.没有class属性 2.如果有class属性并且属性中不包含

  • php+ajax实现带进度条的上传图片功能【附demo源码下载】

    本文实例讲述了php+ajax实现带进度条的上传图片功能.分享给大家供大家参考,具体如下: 运行效果图如下: 代码如下: <?php if(isset($_FILES["FileInput"]) && $_FILES["FileInput"]["error"]== UPLOAD_ERR_OK) { ############ Edit settings ############## $UploadDirectory = 'F:

  • PHP+Ajax实现无刷新分页实例详解(附demo源码下载)

    本文实例讲述了PHP+Ajax实现无刷新分页的方法.分享给大家供大家参考,具体如下: 注:这里使用到的一些类库在前面文章都能找到源代码,因此为了缩短文章篇幅,都指明链接所在. 本文讲解内容为: Ajax 实现无刷新分页.实现原理.代码展示.代码下载. 这里需要说明一些知识: 1.Ajax 无刷新页面的好处:提供良好的客户体验,通过 Ajax 在后台从数据库中取得数据并展示,取缔了等待加载页面而出现的空白状态: 2.那么,Ajax 无刷新页面是运行在动态页面(.php)?还是静态页面(.html/

  • PHP+Ajax实现的无刷新分页功能详解【附demo源码下载】

    本文实例讲述了PHP+Ajax实现的无刷新分页功能.分享给大家供大家参考,具体如下: 注:本文中使用到的一些类库在前面文章都能找到源代码,我会在文中指明链接所在,为了缩短文章篇幅,由此带来的阅读不便,敬请谅解. 本文讲解 Ajax 实现无刷新分页.实现原理.代码展示.代码下载. 这里需要说明一些知识: 1.Ajax 无刷新页面的好处:提供良好的客户体验,通过 Ajax 在后台从数据库中取得数据并展示,取缔了等待加载页面而出现的空白状态: 2.那么,Ajax 无刷新页面是运行在动态页面(.php)

随机推荐