Asp.Net--回调技术

实现回调技术需要以下步骤:

1.实现ICallbakEventHandler

2.实现接口中的方法:RaiseCallbackEvent

3.实现GetCallbackResult

方法 解释 参数
void RaiseCallbackEvent(string eventArgument) 处理以控件为目的的回调事件 表示要传递到事件处理程序的事件参数
string GetCallbackResult() 返回以控件为目的的回调事件的结果  

先看例子,再来解释:

1.建立一个aspx页面,内容如下:

页面代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>无标题页</title>
</head>
<body>
    <form id="form1" runat="server">
        <input type="text" id="txtname" name="txtname" onblur="CallServer(this.value,null)" />
        <span id="msg"></span>
        <input type="submit" value="Submit" />
        <script type="text/javascript">
            function Success(args,context){
                document.getElementById("msg").innerText=args;
            }

            function Error(args,context){
                document.getElementById("msg").innerText=args;
            }
        </script>
    </form>
</body>
</html>
此处,并没有看到定义了CallServer函数,也没有看到有调用Success和Error的地方.且看后台.
实现ICallbackEventHandler接口.
后台代码:
    protected void Page_Load(object sender, EventArgs e)
    {
        string reference = Page.ClientScript.GetCallbackEventReference(this, "args", "Success", "", "Error", false);
        string callbackscript = "function CallServer(args,context){\n" +
            reference + ";\n}";
        Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "callback", callbackscript, true);
    }

    public string GetCallbackResult()
    {
        return ViewState["result"].ToString();
    }

    public void RaiseCallbackEvent(string eventArgument)
    {
        if (eventArgument.Equals("admin"))
        {
            ViewState["result"] = "不可以被使用!";
        }
        else
        {
            ViewState["result"] = "可以使用";
        }
    }

此时,看到了关于Page.ClientScript.GetCallbackEventReference的使用,同时也看到了CallServer方法的定义.且看GetCallbackEventReference方法的定义:

GetCallbackEventReference:获取一个对客户端参数的引用;调用该函数时,将启动一个对服务器事件的回调.即:返回一个函数,该函数是可以将页面提交到服务器.

其中,在例子中使用的函数参数的解释如下:

GetCallbackEventReference(Control control,string argument,string clientcallback,string context,string clientErrorcallback,bool useAsync)

control:处理客户端回调的服务器Control.

argument:一个参数,该参数从客户端脚本传递给服务器的RaiseCallbackEvent事件.

clientCallback:一个客户端函数,用于处理当事件成功运行时的函数

context:启动回调之前,在客户端计算的客户端脚本,脚本的结果传递给事件处理程序.

clientErrorcallback:一个客户端函数,用于处理当事件失败时运行的函数.(本例中虽然有该参数,但是实际上并未使用)

useAsync:true表示异步执行回调,false表示同步执行回调

运行页面,查看效果,是否发现,页面在进行用户判断时不再进行整页的刷新.

页面执行流程如下:

1.当textbox失去焦点时,调用CallServer方法

2.CallServer方法将this.value值传入RaiseCallbackEvent方法的参数中,然后进行判断,随后调用GetCallbackResult()方法

3.此时,再执行页面中定义的Success方法.

查看运行页面的源代码,形成的客户端HTML代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>
	无标题页
</title></head>
<body>
    <form name="form1" method="post" action="Default2.aspx" id="form1">
<div>
<input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />
<input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />
<input type="hidden" name="__VIEWSTATE" id="__VIEWSTATE" value="/wEPDwUJNzgzNDMwNTMzZGS4em2NMZLtsU4YN7EFuXT4tLpJrA==" />
</div>

<script type="text/javascript">
//<![CDATA[
var theForm = document.forms[‘form1‘];
if (!theForm) {
    theForm = document.form1;
}
function __doPostBack(eventTarget, eventArgument) {
    if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
        theForm.__EVENTTARGET.value = eventTarget;
        theForm.__EVENTARGUMENT.value = eventArgument;
        theForm.submit();
    }
}
//]]>
</script>

<script src="/kongjian/WebResource.axd?d=KYfh-S4VutWcM_01AnkeqQ2&amp;t=633934581566718750" type="text/javascript"></script>

<script type="text/javascript">
//<![CDATA[
function CallServer(args,context){
WebForm_DoCallback(‘__Page‘,args,Success,"",Error,false);
}//]]>
</script>

        <input type="text" id="txtname" name="txtname" onblur="CallServer(this.value,null)" />
        <span id="msg"></span>
        <input type="submit" value="Submit" />
        <script type="text/javascript">
            function Success(args,context){
                document.getElementById("msg").innerText=args;
            }

            function Error(args,context){
                document.getElementById("msg").innerText=args;
            }
        </script>

<script type="text/javascript">
//<![CDATA[

WebForm_InitCallback();//]]>
</script>
</form>
</body>
</html>

注意页面中这段代码:

<script type="text/javascript">
//<![CDATA[
function CallServer(args,context){
WebForm_DoCallback(‘__Page‘,args,Success,"",Error,false);
}//]]>
</script>
此段代码正是在pageload事件中生成的
    protected void Page_Load(object sender, EventArgs e)
    {
        string reference = Page.ClientScript.GetCallbackEventReference(this, "args", "Success", "", "Error", false);
        string callbackscript = "function CallServer(args,context){\n" +
            reference + ";\n}";
        Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "callback", callbackscript, true);
    }

此时,再来看WebForm_DoCallback方法.

将源代码中一段script代码下下来./kongjian/WebResource.axd?d=KYfh-S4VutWcM_01AnkeqQ2&amp;t=633934581566718750

查找其中的WebForm_DoCallback方法代码,简单列出一部分:

    var xmlRequest,e;
    try {
        xmlRequest = new XMLHttpRequest();
    }
    catch(e) {
        try {
            xmlRequest = new ActiveXObject("Microsoft.XMLHTTP");
        }
        catch(e) {
        }
    }
    var setRequestHeaderMethodExists = true;
    try {
        setRequestHeaderMethodExists = (xmlRequest && xmlRequest.setRequestHeader);
    }
    catch(e) {}
    var callback = new Object();
    callback.eventCallback = eventCallback;
    callback.context = context;
    callback.errorCallback = errorCallback;
    callback.async = useAsync;

看到这段代码,会发现,原来已经建立的xmlHttpRequest对象了.后面就不说了.

时间: 2024-08-29 22:07:31

Asp.Net--回调技术的相关文章

Asp.net回调技术Callback学习

.aspx: Html代码   <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.o

【ASP.NET 基础】Page类和回调技术

Page 类有一个 IsPostBack 属性,这个属性用来指示当前页面是第一次加载还是响应了页面上某个控件的服务器事件导致回发而加载. 1.asp.net页面的声明周期 asp.net页面运行的时候将经历一个声明周期,这个生命周期中会进行一系列的操作,调用一系列的方法.了解asp.net页面的生命周期对于精确控制页面的控件呈现方式和行为非常重要. 一般说来一个常规页面要经历如下几个生命周期阶段:  阶段  说明  页请求  页请求发生在页生命周期开始之前.用户请求页时,ASP.NET 将确定是

谈谈-Android中的接口回调技术

Android中的接口回调技术有很多应用的场景,最常见的:Activity(人机交互的端口)的UI界面中定义了Button,点击该Button时,执行某个逻辑. 下面参见上述执行的模型,讲述James对Android接口回调技术的理解(结合前人的知识和自己的实践). 使用一个比喻很形象地说明:客户端有个疑问打电话请教服务端,但服务端无法现场给出解答,相互之间约定:服务端一旦有答案,使用电话的方式反馈给客户端. 以上有三个主体:客户端.服务端和接口(方式). 接口回调的原理框图说明: Demo界面

Orchard 基于 ASP.NET MVC 技术的免费开源内容管理系统

Orchard 是由微软公司创建,基于 ASP.NET MVC 技术的免费开源内容管理系统: 可用于建设博客.新闻门户.企业门户.行业网站门户等各种网站 简单易用的后台界面 性能稳定,功能齐全 热拔插模块化架构提供超强可扩展性 BSD 协议授权,可用于商业闭源项目 下载地址:https://orchard.codeplex.com/releases/view/119931 相关博客:http://www.orchardch.com/Blog 一个基于Orchard的开源CRM --coevery

基于ASP.NET WPF技术及MVP模式实战太平人寿客户管理项目开发(Repository模式)

亲爱的网友,我这里有套课程想和大家分享,如果对这个课程有兴趣的,可以加我的QQ2059055336和我联系. 课程背景 本课程是教授使用WPF.ADO.NET.MVVM技术来实现太平人寿保险有限公司保险客户管理系统,是学习WPF开发中的一门主打课程之一. WPF是一个框架,它供程序员开发出媲美Mac程序的酷炫界面. Blend是一种工具,可以在美工板上绘制形状.路径和控件,然后修改其外观和行为,从而直观地设计应用程序 Repository\MVVM\MVP设计模式是WPF常用的系统架构 Auto

ASP.NET相关技术整理

来源:http://blog.csdn.net/zhoufoxcn/article/details/1857097 ASP.NET相关技术整理

Android中的接口回调技术

Android中的接口回调技术有很多应用的场景,最常见的:Activity(人机交互的端口)的UI界面中定义了Button,点击该Button时,执行某个逻辑. 下面参见上述执行的模型,讲述James对Android接口回调技术的理解(结合前人的知识和自己的实践). 使用一个比喻很形象地说明:客户端有个疑问打电话请教服务端,但服务端无法现场给出解答,相互之间约定:服务端一旦有答案,使用电话的方式反馈给客户端. 以上有三个主体:客户端.服务端和接口(方式). 接口回调的原理框图说明: Demo界面

ASP.NET Core技术研究-探秘依赖注入框架

原文:ASP.NET Core技术研究-探秘依赖注入框架 ASP.NET Core在底层内置了一个依赖注入框架,通过依赖注入的方式注册服务.提供服务.依赖注入不仅服务于ASP.NET Core自身,同时也是应用程序的服务提供者. 毫不夸张的说,ASP.NET Core通过依赖注入实现了各种服务对象的注册和创建,同时也实现了面向抽象的编程模式和编程体验,提升了应用程序的扩展性. 今天,我们普及一下ASP.NET Core中依赖注入的一些基本知识. 一.服务的注册 我们通过创建一个ASP.NET C

ASP.NET Core技术研究-探秘Host主机启动过程

原文:ASP.NET Core技术研究-探秘Host主机启动过程 当我们将原有ASP.NET 应用程序升级迁移到ASP.NET Core之后,我们发现代码工程中多了两个类Program类和Startup类. 接下来我们详细探秘一下通用主机Host的启动过程. 一.Program类的Main函数入口 Program类最重要的功能就是启动主机,这里有一个主机的概念,是ASP.NET Core全新引入的. 主机负责应用程序启动和生存期管理. 同时,主机也是封装应用程序资源的对象: 依赖注入 (DI)