詳解如何實現最基本的AJAX框架 ajax技術

Asp.Net 2.0自带的客户端回调

Asp.Net 2.0已经发布。2.0有了许多新特性,客户端回调就是其中之一。客户端回调允许我们不经过回发而调用服务器端的方法,与AJAX提供的功能是一致的,但是不如AJAX灵活,AJAX可以自定义调用的方法,2.0自带的回调功能却不行。要使用客户端回调功能必须实现System.Web.UI.IcallbackEventHandler接口。

这个接口包含两个方法:
詳解如何實現最基本的AJAX框架 ajax技術 // 客户端回调时固定调用此方法
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術
public   void  RaiseCallbackEvent(String eventArgument)
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
// 执行完RaiseCallbackEvent后将调用此方法。此方法的返回值将被发回客户端
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術
public   string  GetCallbackResult()



例一:


.cs:

String cbReference = Page.ClientScript.GetCallbackEventReference(

this,"arg", "ReceiveServerData", "context");

String callbackScript;

callbackScript = "function CallServer(arg, context)" + "{ " + cbReference + "} ;";

Page.ClientScript.RegisterClientScriptBlock(

this.GetType(),"CallServer", callbackScript, true);

javascript:

AJAX介绍

AJAX并不是一种新的技术,而是一些已有技术的有机结合,主要包括:XmlHttp、Reflect。一个AJAX框架基本上包括:一个自定义的HttpHandler、一段JavaScript代码。

AJAX运行机制

以前我们使用XmlHttp实现无刷新页面的时候,是用XmlHttp来请求一个隐藏的页面,使用(Asp/Asp.Net)自带的HttpHandler,而在AJAX中,我们请求的也是一个隐藏的页面,不同的是这个页面的HttpHandler是由我们自己来实现。 打造自己的AJAX:

1.首先我们要实现一个Http处理程序(HttpHandler)来响应客户端的请求:

实现自定义的HttpHandler需要实现IHttpHandler接口。

该接口包含一个属性和一个方法:
詳解如何實現最基本的AJAX框架 ajax技術 bool  IHttpHandler.IsReusable
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
void  IHttpHandler.ProcessRequest(HttpContext context)
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術Example: 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
bool  IHttpHandler.IsReusable
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
{
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
get return true; }
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術}

詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
void  IHttpHandler.ProcessRequest(HttpContext context)
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
{
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 context.Response.Clear(); 
//获取要调用的方法
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術 
string methodName = context.Request.QueryString["me"];
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
//获取程序集信息。
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
//Czhenq.AJAX.Class1.Dencode是自定义的字符串编码方法
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術 
string AssemblyName = Czhenq.AJAX.Class1.Dencode(context.Request.QueryString["as"]); 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
//获取方法的参数 
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術 
string Arguments = context.Request.QueryString["ar"]; //开始调用方法
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術 Type type 
= Type.GetType(AssemblyName);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 MethodInfo method 
= type.GetMethod(methodName, 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術BindingFlags.NonPublic 
| BindingFlags.Public | BindingFlags.Static | BindingFlags.Instance); 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
if (method != null
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
{
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
//参数使用","分隔
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術
string[] args = Arguments.Split(",".ToCharArray());
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術ParameterInfo[] paras 
= method.GetParameters(); 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
object[] argument = new object[paras.Length];
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
for (int i = 0; i < argument.Length; i++)
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
{
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
if (i < args.Length) 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
//因为XmlHttp传递过来的参数全部时String类型,所以必须进行转换
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
//这里只将参数转换为Int32,并不做其他考虑。 
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術argument[i] 
= Convert.ToInt32(args[i]);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 }

詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術}

詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
object value = method.Invoke(Activator.CreateInstance(type, true), argument);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
if (value != null) context.Response.Write(value.ToString());
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
else context.Response.Write("error"); 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 }

詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
//处理结束 
詳解如何實現最基本的AJAX框架 ajax技術

詳解如何實現最基本的AJAX框架 ajax技術 context.Response.End();
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術}

詳解如何實現最基本的AJAX框架 ajax技術 
詳解如何實現最基本的AJAX框架 ajax技術

 

 

2. 客户端Javascript代码:

詳解如何實現最基本的AJAX框架 ajax技術 function  CallMethod(AssemblyName,MethodName,Argus)
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
{
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
var args = ""
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術 
for(var i=0;i
詳解如何實現最基本的AJAX框架 ajax技術args 
+= Argus[i] + ",";
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
if(args.length>0) args = args.substr(0,args.length-1);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術
var xmlhttp = new ActiveXObject('Microsoft.XMLHTTP'); 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術url 
= "AJAX/AJAX.czhenq?as=" + AssemblyName + "&me=" + MethodName +"&ar="+ args; 
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術xmlhttp.open(
"POST",url,false);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術xmlhttp.send();
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術alert(xmlhttp.responseText);
詳解如何實現最基本的AJAX框架 ajax技術
詳解如何實現最基本的AJAX框架 ajax技術}



3.一个简单的AJAX框架已经实现。现在写段代码来测试.
使用自己的AJAX

1.新建一个网站,并应用刚才你编写的HttpHandler。并在网站的Web.config中注册你的HttpHandler,说明那些请求将使用你编写的Handler来处理。下面的内容说明:所有以"czq"结尾的请求,都将使用"Czhenq.HttpHandlerFactory"来处理。

 



type="Czhenq.HttpHandlerFactory, Czhenq.AJAX"/>



2.添加一个web页面,将刚才的脚本拷贝到页面中,并添加一个你要调用的方法。

private string Add(int i, int j)

{

 return TextBox1.Text;

}



3.在页面中放置一个HiddenField控件,命名为AssemblyName。 并在Page_Load中添加如下代码:

string assemblyName = Czhenq.AJAX.Class1.Encode(

typeof(_Default).AssemblyQualifiedName);

AssemblyName.Value = assemblyName;



4.页面中添加如下脚本:

var assemblyName = document.getElementById("AssemblyName");

var argus = new Array();

argus.push("100");

argus.push("200");

CallMethod(assemblyName,"Add",argus);



总结 AJAX并不是一种新的技术,它只是一些已有技术的有机结合,我们可以将AJAX简单的理解为:AjAx是对JavaScript调用XmlHttp的封装,它改变的是代码书写方式。

Encode 与 Dencode实现:

public static string Encode(string value)

{

 byte[] bytes = ASCIIEncoding.ASCII.GetBytes(value);

 return Convert.ToBase64String(bytes);

}

public static string Dencode(string value)

{

 byte[] bytes = Convert.FromBase64String(value);

 return ASCIIEncoding.ASCII.GetString(bytes);

}


 

你可能感兴趣的:(ajax框架)