`
zendj
  • 浏览: 122180 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

详解如何实现最基本的AJAX框架

阅读更多

详解如何实现最基本的AJAX框架


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

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

这个接口包含两个方法

//客户端回调时固定调用此方法

public void RaiseCallbackEvent(String eventArgument)

//执行完RaiseCallbackEvent后将调用此方法。此方法的返回值将被发回客户端

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接口。

该接口包含一个属性和一个方法:

bool IHttpHandler.IsReusable

void IHttpHandler.ProcessRequest(HttpContext context)

Example:

bool IHttpHandler.IsReusable

{

 get { return true; }

}

void IHttpHandler.ProcessRequest(HttpContext context)

{

 context.Response.Clear(); //获取要调用的方法

 string methodName = context.Request.QueryString["me"];

 //获取程序集信息。

 //Czhenq.AJAX.Class1.Dencode是自定义的字符串编码方法

 string AssemblyName = Czhenq.AJAX.Class1.Dencode(context.Request.QueryString["as"]);

//获取方法的参数

 string Arguments = context.Request.QueryString["ar"]; //开始调用方法

 Type type = Type.GetType(AssemblyName);

 MethodInfo method = type.GetMethod(methodName,

BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Static | BindingFlags.Instance);

 if (method != null)

 {

//参数使用","分隔

string[] args = Arguments.Split(",".ToCharArray());

ParameterInfo[] paras = method.GetParameters();

object[] argument = new object[paras.Length];

for (int i = 0; i < argument.Length; i++)

{

 if (i < args.Length) {

//因为XmlHttp传递过来的参数全部时String类型,所以必须进行转换

//这里只将参数转换为Int32,并不做其他考虑。

argument[i] = Convert.ToInt32(args[i]);

 }

}

object value = method.Invoke(Activator.CreateInstance(type, true), argument);

if (value != null) context.Response.Write(value.ToString());

else context.Response.Write("error");

 }

 //处理结束

 context.Response.End();

2. 客户端Javascript代码:

function CallMethod(AssemblyName,MethodName,Argus)

{

 var args = "";

 for(var i=0;i
args += Argus[i] + ",";

if(args.length>0) args = args.substr(0,args.length-1);

var xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');

url = "AJAX/AJAX.czhenq?as=" + AssemblyName + "&me=" + MethodName +"&ar="+ args;

xmlhttp.open("POST",url,false);

xmlhttp.send();

alert(xmlhttp.responseText);

}

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中各种框架的应用和详解

    - **AJAX UI组件**:DWR提供了一些基本的UI组件,如AutoComplete,方便快速开发。 ### 2. **Prototype框架** Prototype是一个JavaScript库,旨在简化DOM操作,提供强大的面向对象功能,并增强AJAX功能。以下是一些...

    ASP.NET Ajax框架与组件

    ### ASP.NET Ajax框架与组件详解 #### 一、引言 随着互联网技术的快速发展,用户对于Web应用的体验有了更高的要求。传统的Web应用程序通常需要在每次用户交互时重新加载整个页面,这种做法不仅效率低下,而且用户...

    十大AJAX框架

    **十大AJAX框架详解** AJAX(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。随着Web开发的不断进步,AJAX框架应运而生,它们为开发者提供了更加便捷和高效的手段来...

    ajax框架

    **Ajax 框架详解:以 DWR 为例** Ajax(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下更新部分网页的技术。它通过后台与服务器进行少量数据交换,使网页实现异步更新,极大地提升了用户体验...

    一套开源的基于纯JS实现的的AJAX框架源码及程序例子

    **AJAX 框架详解** AJAX (Asynchronous JavaScript and XML) 是一种在无需刷新整个页面的情况下,能够更新部分网页的技术。它通过在后台与服务器进行少量数据交换,使得网页实现异步更新。本资源提供了一套开源的...

    通用的ajax 框架

    在本篇文章中,我们将深入探讨如何构建一个通用的Ajax框架,并涉及与JSON数据的处理。 **一、Ajax基础** Ajax并非一种编程语言,而是使用一组相关的Web开发技术的集合。其主要组件包括: 1. **XMLHttpRequest对象...

    JAVA AJAX框架 DWR

    **JAVA AJAX框架 DWR详解** DWR(Direct Web Remoting)是一个开源的Java库,它使得JavaScript和服务器端的Java代码可以直接进行交互,无需处理复杂的HTTP请求和响应。这种技术在Web开发中被称为Ajax(Asynchronous...

    简单ajax框架

    本篇文章将围绕一个简单的Ajax框架——Ajax.js展开,深入探讨其工作原理、核心功能以及如何在实际项目中应用。 ### 1. Ajax.js框架概述 Ajax.js是一个轻量级的JavaScript库,专注于提供易于使用的Ajax交互功能。它...

    ajax-ext框架

    **Ajax-ext框架详解** Ajax-ext框架是一款强大的JavaScript库,专为构建富客户端应用程序而设计,它结合了Ajax技术的优势和ExtJS库的功能,提供了一种高效、可扩展的方式来实现动态和交互式的Web应用。框架的核心...

    ajax dwr 框架实现二级联动下拉列表源码

    **Ajax DWR 框架实现二级联动下拉列表源码详解** Ajax(Asynchronous JavaScript and XML)是一种在无需刷新整个网页的情况下,能够更新部分网页的技术。DWR(Direct Web Remoting)则是一个用于Java web应用的开源...

    VS自带AJAX框架

    **VS自带AJAX框架详解** 在.NET开发领域,Visual Studio(VS)作为一款强大的集成开发环境,为开发者提供了丰富的工具和框架支持。其中,VS自带的AJAX框架是微软为Web应用程序开发提供的一个核心组件,它使得开发者...

    ajax详解.pdf

    ### Ajax详解知识点归纳 #### 一、Ajax概述 **1.1 什么是Ajax** - **定义**: Ajax(Asynchronous JavaScript and XML,异步JavaScript和XML)并非一项全新的技术,而是一种利用现有技术的新方法,旨在改善用户...

    AJAX 框架 源码 使用Demo

    2. **JavaScript文件**:实现AJAX逻辑,如创建请求、处理响应。 3. **服务器端脚本**:响应AJAX请求,可以是PHP、Python、Node.js等。 4. **CSS文件**:样式文件,可能用于美化示例界面。 通过阅读和分析这些Demo,...

    ajax框架与struts框架的最佳结合讲解源码.

    在"wangmeng.cn"这个压缩包中,可能包含了实现Ajax与Struts框架整合的源代码示例。这些源码可能包括了Action类的扩展、Ajax请求的拦截器、返回JSON数据的Result配置以及前端JavaScript的Ajax调用实现。通过阅读和...

    Bootstrap进度条与AJAX后端数据传递结合使用实例详解

    Bootstrap进度条与AJAX后端数据传递结合使用实例详解 Bootstrap进度条与AJAX后端数据传递结合使用是Web开发中常见的技术结合,通过Bootstrap进度条展示数据加载的进度,提高用户体验,AJAX技术则可以实现在页面不...

    spring boot+mybatis+layui实现的项目基本框架

    《基于Spring Boot、MyBatis与Layui的项目基础框架构建详解》 在现代Web应用开发中,Spring Boot以其简化配置、快速启动的优势成为首选的框架。MyBatis作为轻量级持久层框架,提供了灵活的数据访问能力,而Layui则...

    最棒的AJAX框架DOJO中文手册

    这个“最棒的AJAX框架DOJO中文手册”提供了全面的中文指南,便于开发者更有效地理解和应用Dojo。 ### 1. AJAX 技术 AJAX(Asynchronous JavaScript and XML)是一种在无需重新加载整个网页的情况下,能够更新部分...

    基于ASP.NET Ajax框架实现表单验证编程原理

    ### 基于ASP.NET Ajax框架实现表单验证编程原理详解 #### 一、引言 随着Web应用程序的复杂度不断提高,确保用户数据的安全性和准确性变得尤为重要。ASP.NET Ajax框架提供了一种强大的方式来增强用户体验,并同时...

    AJAX框架汇总借鉴.pdf

    **主要AJAX框架详解** 1. **Bindows**:Bindows是一款无需安装客户端插件的JavaScript框架,它利用DHTML、JavaScript、CSS和HTML技术创建出类似桌面应用的Web体验。Bindows强调面向对象的设计,提供了丰富的API和...

    AJAX框架

    **AJAX框架详解** 在Web开发领域,AJAX(Asynchronous JavaScript and XML)是一种核心技术,它使得网页可以异步地与服务器进行数据交互,无需刷新整个页面就能更新部分内容,从而提高了用户体验。AJAX框架是实现这...

Global site tag (gtag.js) - Google Analytics