`
索菲亚.  ぅ
  • 浏览: 16406 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
社区版块
存档分类
最新评论

ASP.NET 2.0中的脚本回调(Script Callback) [转]

    博客分类:
  • NET
阅读更多

原作者:Dino Esposito

出处:codeguru

http://www.codeguru.com/columns/Experts/article.php/c9321/

发表时间:2005-2-28

翻译:Arrix <arrix@163.com>

 

       让我们面对这个事实吧:Web开发人员愿意付出一切来换取一种可以让他们避免页面刷新的开发工具。想想这个常见的情景:你在一个ASP.NET页面上添加了一个grid控件(control)用来显示用户导航栏。每当用户为了显示几行新的数据而点击时,页面将回传(postback)服务器,由服务器处理后又原封不动地重现(除了grid控件(control)中的几行新数据)。这个过程导致了严重的性能问题,尤其是对于复杂的大页面。开发者们不禁要问:为什么每次处理用户事件都非要下载50Kb的内容(而且还得上传其中的相当一部分同样多次)

       不用回传(postback)整个页面就能上传客户端数据是web开发者们一个期待已久的梦想。理想情况下,他们应该能触发客户端代码调用服务器来处理事件,并用返回的数据仅仅更新页面中受影响的部分。

       ASP.NET 1.x 以及传统的 ASP 都可以实现这个功能,但开发人员必须使用ActiveX控件(ActiveX control)或者至少是Java小程序(Java applet)来做中介(intermediary)。这种中介(intermediary)的作用是接收客户端脚本的调用,并建立一个并行而不被用户察觉的连接到某个服务器页面。服务器页面根据接收到的输入产生相应输出。输出经连接返回到客户端,客户端便可通过DHTML对象模型(Dynamic HTML object model)来更新页面显示。

       ASP.NET 2.0 抽象了建立服务器连接并解析返回数据的逻辑。ASP.NET 2.0中的脚本回调(script callback)提供了一种成熟而立即可用的机制,从而大大简化了上面的过程。更为重要的是,脚本回调(script callback)隐藏了很多实现细节并且帮我们解决了一大堆浏览器兼容性问题。

 

使用脚本回调(script callback)的要求

       ASP.NET脚本回调(script callback)的核心包括一些客户端JavaScript,用来安并排处理程序中客户端和服务器间的数据往返。所以,使用脚本回调(script callback)的先决条件是服务段代码侦听客户端的调用。回调由客户端的中介(intermediary)处理,而用户可以继续进行操作。回调并不立即影响当前的页面,给用户造成一种假象,仿佛所有的一切都像是在传统的桌面应用程序中。因此,第二个要求就是浏览器支持DHTML并实现了高级的文档对象模型(DOM)。没有这些功能,多数下载下来的数据都没什么用。

    在微软的世界里,第一次回调(callback)的实现是Remote Scripting (RS)。RS使用Java小程序(Java applet)连接服务器并要求用一个ASP页面来处理请求。另外,此ASP页面提供一个量身定做的对象模型(object model)——一种共有的通用接口—— 为了让交互启效。在ASP.NET中,总体上模型很相似,但使用的工具有所不同。

 

ASP.NET脚本回调(script callback)的工作原理

       ASP.NET 2.0脚本回调(script callback)XmlHttpRequest DOM对象(XmlHttpRequest DOM object)来建立连接。(Internet Explorer来讲,脚本回调(script callback)要求版本至少是5.0) 远程调用的目标可以是某个特定的Server Control(例如,新的GridView控件(GridView control)),也可以是页面本身。通常,此目标必须是个实现了ICallbackEventHandler的对象。

       下面几段向您展示怎样增强你的页面使其支持脚本回调(script callback)

       第一步是标识触发操作的HTML元素(HTML element)。典型情况下,此元素(element)是一个可供用户点击的按钮(button)或链接(link)。关键的一点是此元素(element)引发的事件不会被浏览器自动处理并导致一次回调(postback)。例如,你不能用<asp:button>元素(element)来触发回调(callback),因为<asp:button>会产生一个提交按钮(submit button)。如果你想用一次按钮点击来开始一次操作,下面的代码非常不错: <input type="button" runat="server" id="callbackStarter" value="View Details">



 

 

这个按钮(button)——HtmlInputButton控件(HtmlInputButton control)的实例——需要一些特定的JavaScript代码来处理点击(click)事件。你可以添加如下代码到Page_Load事件中: callbackStarter.Attributes["onclick"] = String.Format("JavaScript:{0}", callbackRef);



 

 

 

怎样确定将事件绑定到那个脚本函数呢?要靠Page类中的GetCallbackEventReference函数。看这个例子: string callbackRef = GetCallbackEventReference( this, "document.all['cboEmployees'].value", "UpdateEmployeeViewHandler", "null", "null");



 

       GetCallbackEventReference函数的第一个参数制定了服务器端将要处理回调的目标对象。如果传入的是this,则表示页面本身。也可以传入任何实现了ICallbackEventHandler的页面控件(page control)的引用。在任何情况下,客户端的提交动作(submit action)会提交至和标准回传(postback)机制相同的ASPX页面。

       第二个参数是一个JavaScript常量表达式,表示传给服务器的输入数据。在上面的代码中,一个下拉列表(dorp-down list)当前选中元素(element)的值被传入。

       第三个参数是一个用户定义在<script>块中的JavaScript回调(callback)函数名。回调(callback)执行后,此函数最终负责页面的更新。最后两个可选参数可用来指定错误处理函数(error handler)和上下文对象(context object)

       GetCallbackEventReference函数将产生如下的脚本调用: WebForm_DoCallback( pageID, input, UpdateEmployeeViewHandler, null, null);



 

 

此函数的代码会自动下载到客户端并通过<script>标签添加到页面响应(page's response)中。WebForm_DoCallback 使用XmlHttpRequest DOM对象(XmlHttpRequest DOM object)回调(call back)当前页面的URL。与此同时,它会添加一些额外的隐藏域(hidden field)以便服务器区分更简单的轻量级回调(callback)请求和一般回传(postback)请求。

       处理请求时,ASP.NET运行时(runtime)标识出调用的目标对象(传给GetCallbackEventReference的第一个参数),确认它实现了ICallbackEventHandler接口后调用RaiseCallbackEvent方法: public virtual string RaiseCallbackEvent(string eventArgument){ // Do something with the input and generate the output return ProcessTheCall(eventArgument);}



 

 

RaiseCallbackEvent的接收参数和返回值均为字符串(string)类型。它也包含任意处理客户端输入并返回响应(response)的代码。客户端和服务器间的数据交换仅能通过字符串(string)进行。一个字符串(string)可包含任何信息,包括序列化的对象(serialized object)。其格式可由你随心所欲指地定。的返回值将被传入客户端的JavaScript回调(callback)函数(前面代码中的UpdateEmployeeViewHandler函数)。这里是其必须的原形(prototype): function UpdateEmployeeViewHandler(result, context){ // "result" is the return value of RaiseCallbackEvent // TO DO: Process the string and update the page using DHTML}



 

       上面说过,脚本回调(script callback)并不适用于所有浏览器,尽管最新的浏览器,包括Internet Explorer 5+, Netscape 6+, and Safari 1.2+都能行。MicrosoftASP.NET 2.0中加入了两个新的browser bapabilitiesSupportsXmlHttpSupportsCallback以便开发人员检查方案的可行性。

一条让页面刷新更快的告诫

       尽管脚本回调(script callback) 定义在ASP.NET 2.0中,要使其在ASP.NET 1.1里工作也并不很困难。在ASP.NET 2.0中,很多服务器控件(server control)借助脚本回调(script callback)提供了更迅速的页面刷新。最突出的例子也许是GridView控件(GridView control),作为DataGrid的接班人,选择性地运用脚本回调(script callback)实现分页显示记录。

       正如前面所说,脚本回调(script callback)依赖于文档对象模型(DOM)XmlHttpRequest对象。在Internet Explorer中,此文档对象模型对象(DOM object)通过ActiveX控件(ActiveX control)实现——Microsoft.XmlHttp。在IE中浏览这样的页面时,你必须适当降低安全设置以允许ActiveX控件(ActiveX control)能被脚本调用。在其他以同样方式实现XmlHttpRequest文档对象模型对象(DOM object)的浏览器中,这是不必要的。事实上,基于Mozilla的浏览内置支持了HTTP请求功能器,而没用使用ActiveX控件(ActiveX control)——这也是在Internet Explorer 7.0中被寄予厚望的功能。

分享到:
评论

相关推荐

    ASP.NET2.0实现无刷新客户端回调的Callback机制

    在ASP.NET 2.0中,引入了一种新的技术,即客户端回调(Client Callback)机制,也称为 Partial Page Rendering 或 UpdatePanel,这使得开发者能够实现无刷新页面更新,提高用户体验。 客户端回调机制的核心是通过...

    ASP.NET 2.0客户端回调的实现分析

    在ASP.NET 2.0中,客户端回调主要通过以下几种方式实现: 1. **UpdatePanel**:这是最常用的实现方式,UpdatePanel是一个服务器控件,可以在客户端呈现为一个IFrame。当UpdatePanel内的控件发生改变时,仅会发送该...

    无刷新asp.net2.0

    "Callback"可能指的是回调函数,这是在异步请求中常见的一种处理机制,当服务器响应完成时,回调函数会被执行,用来处理返回的数据并更新页面。 总的来说,无刷新ASP.NET 2.0技术旨在通过提高交互性、减少网络延迟...

    征服ASP.NET 2.0 Ajax——Web开发技术详解(光盘使用说明)

    - **CallbackRefresh**:利用ASP.NET 2.0的回调特性实现局部刷新。 - **IframeRefresh**:通过嵌入iframe的方式实现局部刷新。 - **JsRefresh**:纯JavaScript方式实现局部刷新。 **第4章:CSS制作方法** - **...

    【ASP.NET编程知识】Asp.net回调技术Callback学习笔记.docx

    ASP.NET回调技术Callback是ASP.NET提供的一种机制,允许客户端脚本和服务器端代码之间进行异步通信。通过使用回调机制,可以实现实时更新页面内容、验证用户输入、获取服务器端数据等功能。 一、ASP.NET回调技术...

    asp.net 使用 回调例子

    在压缩包中的"CallBack"文件可能是实现回调功能的源代码文件,包括.aspx页面、.cs后台代码文件以及可能的.js脚本文件。通过分析这些文件,我们可以学习到如何设置控件、编写服务器端代码以及处理客户端事件的具体...

    datawindwo.net 程序

    这个程序的核心特性是利用脚本回调(Script Callback)功能,这是ASP.NET 2.0引入的一项重要创新。脚本回调机制允许在不重新加载或刷新当前页面的情况下执行服务器端代码,提高了Web应用的用户体验。 在DataWindow ...

    ASP.NET回调函数

    在ASP.NET回调的上下文中,这个目录可能用于存储需要在回调过程中访问或更新的数据。 实现ASP.NET回调的过程大致如下: 1. **客户端准备**:在网页中,使用JavaScript或jQuery创建一个事件监听器,如按钮点击事件...

    asp.net 客户端回调

    ASP.NET 客户端回调(Client Callback)是一种技术,它允许网页部分更新,而无需整个页面刷新,类似于AJAX(Asynchronous JavaScript and XML)的工作原理。这种技术提高了用户体验,因为用户在等待数据加载时可以...

    asp.net:Page类和回调技术

    在传统的ASP.NET Web Forms中,回发会导致整个页面重新加载,而回调则提供了一种更为高效的方式。回调允许开发者只更新页面的一部分,而无需刷新整个页面。ASP.NET AJAX扩展引入了UpdatePanel控件,它利用回调机制...

    ASP.NET AJAX 服务器端 源代码

    此外,ASP.NET AJAX也支持Callback Functions,允许开发者定义在服务器响应完成时执行的回调函数,从而实现更复杂的交互逻辑。 在处理AJAX请求时,还要注意错误处理。ASP.NET AJAX提供了一套完整的错误处理机制,...

    asp.net客户端AJAX

    在ASP.NET中,AJAX回调允许客户端通过JavaScript函数向服务器发送请求,并获取返回的数据。这通常通过调用PageMethods或WebMethods实现,它们是隐藏在代码后面的静态方法,可以直接从客户端JavaScript调用。 7. **...

    基于ASP.NET接口的AJAX异步请求实例(不是控件)

    `PageMethods`是ASP.NET AJAX库的一部分,允许你在脚本中直接调用页面上的静态Web方法。而`WebMethods`是在页面代码后面声明的静态方法,用于处理这些请求。 例如: ```csharp [WebMethod] public static string ...

    asp.net ajax所有的安装文件

    - **Callback**:ASP.NET AJAX中的回调机制允许客户端发送请求到服务器,服务器处理请求后只返回必要的数据,而不是整个页面。 - **Partial Page Rendering**:这是ASP.NET AJAX的核心特性,它减少了网络传输的数据...

    asp.net 常用 AJAX实例

    7. **Callback Events**:通过定义回调事件,开发者可以指定当服务器端处理完成后触发的客户端事件,增强用户反馈。 8. **Error Handling**:在使用AJAX时,错误处理同样重要。ASP.NET提供了错误处理机制,确保即使...

    asp.net+Ajax程序设计

    3. **Callback和Web服务**: ASP.NET AJAX支持回调函数和Web服务,允许客户端JavaScript直接调用服务器上的方法,无需完整页面生命周期。 4. **脚本和服务端通信**: 使用PageMethods或WebMethod特性,开发者可以在...

    asp.net ajax

    8. **Callback Events**:通过ASP.NET AJAX,可以定义服务器端回调事件,这些事件在客户端触发后会调用服务器端代码,然后将结果返回给客户端,无需完整的HTTP请求。 9. **Error Handling**:ASP.NET AJAX提供了...

    利用script脚本引用实现跨域

    本文将详细介绍如何在ASP.NET中通过创建和引用`script`脚本来实现跨域数据传递。 首先,我们要理解什么是同源策略。同源策略是浏览器为了保障用户数据安全而设置的一种机制,它规定了JavaScript只能访问与当前页面...

    .net无刷新例子

    在本例中,"Callback"可能指的是一个具体的实现细节,如使用UpdatePanel或者自定义的回调处理程序。 实现.NET无刷新步骤如下: 1. **创建ASP.NET页面**:首先,创建一个ASP.NET Web Forms页面,并在页面上放置需要...

    .net与javascript脚本的交互方法总结

    使用 ASP.NET 的回调事件(Callback Event)可以实现页面局部刷新,允许 JavaScript 函数调用服务器端方法。首先,页面类需要继承 `ICallbackEventHandler` 接口并实现相关方法: ```csharp public partial ...

Global site tag (gtag.js) - Google Analytics