AjaxPro相关


AJAX在去年已经接触过,但都是使用手动的方法编写客户端代码,再加上被请求的页面,感觉非常累,虽然早听说过AJAX.NET和其他一些第3方开发的框架,却一直没有时间来体验。今天干完手上的活,下了个最新版本的AJAX.NET体验了下

1、准备工作
新建项目,使用.NET1.1就引用下载下来的AJAX.NET的类库AjaxPro.dll,如果是使用.NET2.0 就引用AjaxPro2.dll
首先修改WEB.CONFIG文件
 在<system.web> 节点内增加

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


2、然后在Page_Load事件中注册页面类
如我将使用AJAX的页面类名为‘AjaxControls’,注册语句就这样写:
     
AjaxPro.Utility.RegisterTypeForAjax(typeof(AjaxControls));

红字的地方是我的页面的类名
这句的作用实际上是在页面被请求的时候生成几句调用JS的SCRIPT代码

3、编写服务器端处理函数
        如:
         [AjaxPro.AjaxMethod]
         public string Fun(string str)
         {
              return str;
         }

‘[AjaxPro.AjaxMethod]’这句是关键,函数或方法写法没什么特别的地方,只是要使用这句声明这个函数是由AJAX.NET在页面异步请求的,总之记住要通过AJAX获得数据的后台函数就使用[AjaxPro.AjaxMethod]来声明一下。

4、客户端代码
在我的这个示例中,使用‘Ajax.AjaxControls.Fun("测试用的传递的字符串参数");’请求后台的函数,然后返回一个OBJECT对象,这个OBJECT的VALUE属性就可以得到后台函数的返回值
如:
function doTest()
{
var getobject = Ajax.AjaxControls.Fun("测试用的传递的字符串参数");
alert(getobject.value);
}
Ajax 是我这个项目的命名空间
AjaxControls 是我这个页面的的类名
Fun 很明显就是声明了的那个AJAX可调用的方法名
()中的参数也就是我的Fun函数所需要的参数
doTest() 只是一个客户段的函数,
可以绑到控件的事件中,也可以已不用事件,随便怎么处理
客户端异步请求这个函数所得到的和平时我们用函数返回的稍微不同的就是,平时直接得到函数类型的返回值,而使用AJAX.NET客户端异步请求后台函数得到的是个OBJECT,要通过这个OBJECT的VALUE属性才能得到函数返回的值。
通常这里的客户段脚本还可以这样写:
 
function doTest()
{
Ajax.AjaxControls.Fun("测试用的传递的字符串参数",getdata);
}
function getdata(rv)
{
    alert(rv.value);
}

Ajax.AjaxControls.Fun 中的参数除了对应后台函数的参数外,最后可以使用一个表达式参数,这个参数是某个客户段函数名,设置后,Ajax.AjaxControls.Fun请求后所获得OBJECT对象将被做为 表达式参数函数的一个参数传递到该函数中,然后通过这个OBJECT参数的VALUE就可以获得 AJAX请求后台函数所返回的值了
通过这几个步骤 就可以做出一个简单的使用Ajax.net结合.NET的示例页面了。

下面说说用后的感受:
总体感觉上使用起来很方便,很简单,但是功能不够强大,也许是我初次涉及的缘故,还没摸索出更高级的使用方法,但是在对服务器控件的控制上基本不能实现,需要使用其他方法如获得控件输出样式,然后通过客户端方法加载,还有除了能异步的获得后台请求的函数或方法的返回值之外,其他更具体复杂的操作都需要手动的写代码解决,不过确实是不错的东西,可以很快速的完成某些AJAX的效果。也许还有很多更强大的功能我还没摸索到,希望大家指教 ,补充~

你可能感兴趣的:(Ajax)