AJAX技术的风起云涌,也使得B/S应用的表现力日益增强,大有逐步吞食C/S领地之势。利用ajaxpro.dll,你可以从JavaScript客户调用.NET方法。
首先下载ajaxpro.dll,你可以从http://www.ajaxpro.info/获得。最新版本是6.4.15.1,下载解压后的文件夹中有个AjaxPro.dll,就是它了。使用VS2005新建web项目,并添加对AjaxPro.dll的引用,然后在Web配置文件中添加:
<httpHandlers>
<add verb="POST,GET" path="ajaxpro/*.ashx" type="AjaxPro.AjaxHandlerFactory, AjaxPro"/>
</httpHandlers>
这个配置项表明所有的ajaxpro/*.ashx请求(即从客户发送的Ajax请求)都交给AjaxPro.AjaxHandlerFactory处理,而不是由默认的System.Web.UI.PageHandlerFactory来处理。
新建的web项目有个默认的_Default页面,我们为其加上命名空间如MyAjaxNetTest,然后在_Default的HTML第一句也要加上这个名目空间:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="MyAjaxNetTest._Default" %> 然后在PageLoad中注册本页面到AjaxPro中:
protected void Page_Load(object sender, EventArgs e)
{
AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default));
}
测试一:
一切已经准备就绪了,我们先进行第一个测试,从客户调用服务端的简单方法。首先在_Default类中添加方法:
[AjaxPro.AjaxMethod]
public string GetServerTime()
{
return DateTime.Now.ToString();
}
客户现在可以在JS中调用这个方法了,如
<script type="text/javascript">
function getTime()
{
alert(MyAjaxNetTest._Default.GetServerTime().value);
}
</script>
然后你可以加个HTML的button,onclick处理函数设为getTime()。
<input id="Button1" type="button" value="button" onclick="getTime()"/>
测试二:
为GetServerTime方法添加static修饰,测试仍然成功!
测试三:
简单方法调用已经OK了,GetServerTime方法返回的是一个简单的string,那么服务端可不可以返回稍微复杂一点的对象了?我们来试试。先新建一个Student类:
public class Student
{
public string Name = "sky" ;
public int Age = 26;
}
服务端添加GetStudent方法:
[AjaxPro.AjaxMethod]
public Student GetStudent()
{
return new Student();
}
对应的,客户端添加调用:
function getStudent()
{
var stu = MyAjaxNetTest._Default.GetStudent().value ;
alert(stu.Name + " " + stu.Age) ;
}
依照前面的加个HTML按钮测试getStudent函数,答案是,一切照我们预料的进行,客户js可以访问服务端返回的对象。
测试四:
最后看看能够在客户端提交对象给服务器,先在服务端添加方法:
private Student student = null;
[AjaxPro.AjaxMethod]
public void SetStudent(Student stu)
{
this.student = stu;
string name = this.student.Name;
} 可以在第六行添加断点,然后当客户端调用时,会进入该断点。
客户端添加调用:
function putStudent()
{
var stu = MyAjaxNetTest._Default.GetStudent().value ;
stu.Name = "chenqi" ;
MyAjaxNetTest._Default.SetStudent(stu) ;
}
同样,当调用putStudent这个js方法时,服务端进入断点已经表明客户成功的提交了对象,并且对象的Name字段已经改变为“chenqi”了。
测试五:
前面客户设置的都是Student的public字段,那么访问属性如何了?我们将Student定义更改如下:
public class Student
{
private string name = "sky" ;
public int Age = 26;
public string Name
{
get
{
return this.name;
}
set
{
this.name = value;
}
}
}
再重复前面的测试,结果我想已经在你的料想中了。
单从前面的几个小测试,我已经发现了使用Ajaxpro.dll的方便与迅捷,看来B/S开发不再像我以前感受的那样繁琐了
分享到:
相关推荐
AjaxPro通过提供强大的类型安全和对象透明的Ajax支持,使得开发者能够更容易地将服务器端的对象和方法暴露给客户端调用。它自动处理JSON序列化和反序列化,使得服务器端的方法可以直接在JavaScript中调用,如同本地...
AjaxPro的核心功能是通过提供一组服务器端控件和客户端脚本库,使得开发者能够轻松地将Web服务或页面方法转换为可从JavaScript调用的异步方法。AjaxPro.2.dll可能是该库的一个更新版本,可能包含性能改进、新功能或...
3. 客户端调用:在客户端 JavaScript 中,使用 `AjaxPro.UI.AjaxControlToolkit` 中的函数来调用这些服务器端方法。 4. 处理响应:接收服务器返回的数据,并根据需要更新页面。 **性能和兼容性** `AjaxPro` 的优点...
AjaxPro.2.dll,AjaxPro.2简单易懂例子 前台利用js调用后台方法
这个特性告诉AjaxPro哪些方法应该被暴露给客户端进行异步调用。例如: ```csharp [AjaxPro.AjaxNamespace("MyApp")] public class MyController : System.Web.Mvc.Controller { [AjaxPro.AjaxMethod] public ...
2. **创建Ajax方法**:在C#后台代码中,你可以通过在方法上添加AjaxPro.AjaxMethod特性来标记需要通过Ajax调用的方法。例如: ```csharp [AjaxPro.AjaxMethod] public string GetGreeting(string name) { return...
在实际应用中,Ajax.dll和AjaxPro.dll可以同时使用,Ajax.dll作为基础的AJAX支持,提供基本的异步调用功能,而AjaxPro.dll则可以进一步增强功能,提供更高级的特性和优化的性能。例如,如果一个项目已经使用了Ajax....
在JavaScript中,你可以使用AjaxPro对象来调用后台的C#方法。以下是一个简单的示例: ```javascript var myController = new AjaxPro.MyController(); myController.HelloWorld(function(result) { alert...
AJAX.NET提供的最主要的(也是唯一)的功能就是异步调用服务器端方法,可谓非常纯粹的“基于数据”的AJAX使用方式。这个框架是一个个人作品,有支持.NET 1.1和2.0的版本,它并不属于微软官方,目前已经停止更新。 ...
1. **异步调用**:它允许开发者在客户端通过JavaScript调用服务器端的方法,而无需刷新整个页面,提高了交互性。 2. **JSON序列化**:AjaxPro使用JavaScript Object Notation (JSON)格式来传递数据,这是一种轻量级...
AjaxPro.dll是一个库,它为ASP.NET提供了异步AJAX功能,使得JavaScript可以方便地调用服务器端的代码,实现无刷新的数据交互。 AjaxPro是一个开源的库,它的主要目的是使ASP.NET应用支持AJAX更加简单。通过使用...
在使用AjaxPro.2.dll时,开发者首先需要在服务器端定义一些公开的、可调用的方法,然后在客户端使用JavaScript调用这些方法,实现与服务器的异步通信。AjaxPro会自动处理JSON或XML数据的序列化和反序列化,以及HTTP...
AjaxPro.2.dll 是一个.NET框架的组件,它提供了一种简单的方式来创建基于Ajax的Web方法,这些方法可以在客户端通过JavaScript调用,而无需页面刷新。这极大地提高了用户体验,因为用户可以在不离开当前页面的情况下...
"前台调用后台源码"进一步强调了AjaxPro.dll的主要功能,即允许前端代码与后端服务器进行通信,而无需用户感知到页面刷新。 "源代码"标签意味着你将能够看到整个工作流程,包括服务器端的处理和客户端的调用,这...
3. **代理类**:AjaxPro自动生成的代理类使得开发者能够像调用本地方法一样调用服务器端的方法。这些代理类根据服务器端的类、结构、数据集和枚举自动生成,简化了跨域调用的复杂性。 4. **跨浏览器支持**:AjaxPro...
AjaxPro.dll的工作原理是通过创建JavaScript代理类,这些代理类在客户端浏览器中与服务器端的.NET方法进行交互。当用户在网页上触发一个操作时,例如点击一个按钮,对应的JavaScript函数会被调用。这个函数会调用...
直接把dll文件复制到bin目录,...//前台直接调用函数 function XX() { var result = _Default.SetData(document.getElementById("TextBox1").value).value; if(result=="OK") { alert("成功!"); } } </script>
AjaxPro.2.dll是该框架的一个组件,它包含了一系列用于创建Ajax应用的类和方法。下面我们将详细介绍如何在项目中使用AjaxPro.2.dll。 1. **安装和引用AjaxPro.2.dll** 首先,你需要将AjaxPro.2.dll添加到你的项目...
这些方法在客户端被调用时,会像普通服务器端方法一样执行,但数据交换是在后台完成的,对用户来说是透明的。此外,AjaxPro还支持JSON(JavaScript Object Notation)作为数据交换格式,这比XML更轻量级,传输更快。...