AjaxPro在.NET中的应用
创始人
2024-03-22 08:00:12
0

简单介绍 

Ajax(Asynchronous JavaScript + XML)应用可以仅向服务器发送并取回必需的数据,它使用SOAP或其它一些基于XML的web service接口,并在客户端采用JavaScript处理来自服务器的响应。因为在服务器和浏览器之间交换的数据大量减少,结果我们就能看到响应更快的应用。同时很多的处理工作可以在发出请求的客户端机器上完成,所以Web服务器的处理时间也减少了。

Ajax应用程序的优势在于:

1. 通过异步模式,提升了用户体验

2. 优化了浏览器和服务器之间的传输,减少不必要的数据往返,减少了带宽占用

3. Ajax引擎在客户端运行,承担了一部分本来由服务器承担的工作,从而减少了大用户量下的服务器负载。

配置  

Ajax.net有AjaxPro.dll和Ajax.dll两个版本,这两个版本使用上虽然差不多,但还是有区别的,主要的区别在下面两点:

1. web.config配置文件不一样

Ajax.dll的配置文件写法为

<addverb="POST,GET"path="ajax/*.ashx"type="Ajax.PageHandlerFactory,Ajax"/>

AjaxPro.dll的配置文件写法为

<addverb="*"path="ajaxpro/*.ashx"type="AjaxPro.AjaxHandlerFactory,AjaxPro"/>

2. 调用服务器方法的时候方式不一样,有很多朋友就是因为这个原因,发现命名空间找不到或者对象未定义

引用Ajax.dll的时候,调用服务器方法不要加命名空间,

引用AjaxPro.dll的时候,调用服务器方法需要加命名空间

例如当页面设置为这种设置的时候

<%@Pagelanguage="c#"Codebehind="Test.aspx.cs"AutoEventWireup="false"Inherits="Web.Test"%>

3. 客户端调用方式

Ajax.dll为
  varresponse=Test.GetServerMethod();
  alert(response.value);
  AjaxPro.dll为
  varresponse=Web.Test.GetServerMethod();
  alert(response.value);

具体使用步骤

1. 首先下载AjaxPro 组件。并将AjaxPro.dll引用到网站(或项目)。

2. 修改Web.config。在 元素中添加以下代码。

<configuration>
  <system.web>
  <httpHandlers>
  <!-- Register the ajax handler -->
  <add verb="*" path="ajaxpro/*.ashx" type="AjaxPro.AjaxHandlerFactory, AjaxPro"/>
  </httpHandlers>
  </system.web>
  </configuration>

3. 对AjaxPro在页Page_Load事件中进行运行时注册。如:

protected void Page_Load(object sender, EventArgs e)
    {
      AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));//这的_Default是指页面
       类的类名。如是放在命名空间,则需要写上完整的命名空间(如:namespaces._Default)
    }

4. 创建服务器端方法。只要给一个方法加上[AjaxPro.AjaxMethod]标记,

该方法就变成一个AjaxPro可进行影射调用的方法。如下:

[AjaxPro.AjaxMethod]
    public string getValue(int a,int b)
    { 
       //该方法我们将实现从客户端传入两个数,在服务器端相加计算后返回到客户端。
      return Convert.ToString(a+b);
    } 

5. 客户端调用。

<script language="javascript">
    function getValue(){ 
    _Default.getValue(1,2,getGroups_callback);//该处即调用服务器端的_Default.getValue方法。
        这在里边需要指定个回调函数,以接受服务器端处理完后返回客户端结果。
    form1.TextBox1.value="123";
    } 
    //这个方法用户接受并处理服务器端返回的结果。
    function getGroups_callback(response){
    var dt=response.value;
    alert(dt);
    }
  </script> 

【编辑推荐】

  1. 利用GWT开发高性能Ajax应用
  2. 如何使用ASP.NET AJAX访问Web Services
  3. AJAX和XmlHttpRequest下的Web开发

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...