AutoEventWireup

AutoEventWireup
  Google了一番,大家讨论AutoEventWireup问题可不少,Page指令的AutoEventWireup属性被设置为true(或者如果缺少此属性,因为它默认为true),该页框架将自动调用页事件,即Page_Init、Page_Load等14个方法,在这种情况下,不需要任何显式的Handles子句或委托。但这是怎么实现的呢?.net又怎样根据AutoEventWireup属性来动态编译或者预编译页面呢?我在Google上没有找到答案。
 

大家好,又见面了,我是你们的朋友全栈君。

  Google了一番,大家讨论AutoEventWireup 问题可不少,Page 指令的 AutoEventWireup 属性被设置为 true(或者如果缺少此属性,因为它默认为 true),该页框架将自动调用页事件,即 Page_Init 、 Page_Load等14个方法,在这种情况下,不需要任何显式的 Handles 子句或委托。但这是怎么实现的呢?.net又怎样根据AutoEventWireup 属性来动态编译或者预编译页面呢?我在Google上没有找到答案。

 

Scott(K. Scott Allen) 的一篇文章 Inside AutoEventWireup说了当AutoEventWireup为true时,运行时会查找每个方法并注册到相应的事件里,代码就像下面这样:

  

 

Scott说的非常好,但是运行时又是怎么实现的呢?没办法,又是一阵猛翻asp.net源码,终于找到了,代码如下:

 

 BuildAutomaticEventHookup()方法当AutoEventWireup为false时生成了一个重载TemplateControl类的属性SupportAutoEvents,在TemplateControl里该属性返回true,重载代码如下:

 

 

而在TemplateControl类里通过调用 

 

GetDelegateInformation()方法通过多次调用后会调用到GetDelegateInformationFromMethod()方法来实现根据相应方法(Page_Load等)建立委托,代码如下:


  其中参数methodName就是我们通常使用的Page_Load等等方法名了,方法名是一个私有字符串常量,所以就不能在Page页重写了:

 

 

说到这里我想再补充下,上面的方法名常量有16个,但是前面我说了只有14个方法,这又是怎么回事呢?
 

原来Page_Init,Page_Load,Page_DataBind,Page_PreRender,Page_Unload,Page_Error这六个方法无论TemplateControl实例是什么(TemplateControl实例可能是用户控件,或者页面,因为UserControl和Page类都是继承于TemplateControl类的)都会自动注册到相应的事件中去,而Page_PreInit,Page_InitComplete,Page_PreLoad,

Page_LoadComplete,Page_PreRenderComplete,Page_SaveStateComplete只有在TemplateControl实例同样是Page类实例的情况下才会自动注册到相应的事件中去。仔细看剩下的四个方法名,就会发现这是相对应的两组事件处理函数名,默认会添加Page_AbortTransaction和Page_CommitTransaction,如果找不到这两个方法则会查找OnTransactionAbort和OnTransactionCommit方法进行注册,所以说页面会自动注册14个事件处理函数到相应的事件中去(前提是只有这些方法都存在,才会添加成功哦)。

附注:AbortTransaction和CommitTransaction事件用于Enterprise Service Transactions的情况下(@Page指令必须含有Transaction属性,如Transaction=“Required”). 如果需要了解更多信息,可以看看意大利人Alberto Venditti 04年在codeproject上的这篇文章 .NET Distributed Transactions on Enterprise Services: a demo ,或者联系Scott(此Scott仍然是Allen,并非Scott Guthrie),我看过他的博客,他可是这方面的行家。

 

原文:http://www.0431domain.cn/news/news.aspx/5193

 

 

//=================================================

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/140046.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • CMD命令行杀进程[通俗易懂]

    CMD命令行杀进程[通俗易懂]1、打开CMD,输入tasklist2、根据进程名杀进程taskkill/f/t/imGoogleCrashHandler.exe

    2025年7月26日
    3
  • C++下截取字符串「建议收藏」

    C++下截取字符串「建议收藏」std::string::substrstringsubstr(size_tpos=0,size_tlen=npos)const;功能:按照条件截取字符串参数:pos=截取起始位      len=截取长度用法1:截取下标从2(第3个字符)开始到字符串结尾的字符串stringstr=”ABCDEFG”;str

    2022年5月19日
    36
  • 用java写一个登录界面的完整代码_javaweb简单的用户登录界面

    用java写一个登录界面的完整代码_javaweb简单的用户登录界面一、前言Vue实现QQ第三方登录授权需要获取到APP_ID和回调域地址,关于这2个的获取方式可以参考小编的另外一篇文章Java实现QQ第三方登录温馨小提示:本文基于springboot+vue前后端分离的架构实现三方登录授权主要实现逻辑:前端vue进行授权页面跳转,授权过来拿到后端需要的openID,accessToken参数,最后后端获取到授权用户信息进行业务处理完之后再返回给…

    2025年6月13日
    3
  • string s=new string(“hello”)_result of string concatenation

    string s=new string(“hello”)_result of string concatenation—問題———我的页面上分别有两个按钮Button1,Button2,和两个编辑框TextBox1,TextBox2,我在PAGE_LOAD里加上下面这行代码后,     TextBox1.Attributes.Add(“onkeydown”,”if(event.keyCode==13){document.all.Button1.click();}”);     实现了对Te

    2022年9月26日
    2
  • 微服务架构—服务降级

    微服务架构—服务降级1、简介什么是服务降级?当服务器压力剧增的情况下,根据实际业务情况及流量,对一些服务和页面有策略的不处理或换种简单的方式处理,从而释放服务器资源以保证核心交易正常运作或…

    2022年6月11日
    46
  • 剖析RT-Thread中console与finsh组件实现(2)[通俗易懂]

    剖析RT-Thread中console与finsh组件实现(2)[通俗易懂]接上一章剖析RT-Thread中finsh组件实现(1),rt_device具体定义如下:其中内核基类定义如下:所以刚才串口1初始化后名称被初始化为了“usart1”,与刚才设置终端时入参刚好可以匹配。而这个标志是类型标志,串口类型即为RT_Object_Class_Device,同时也是一个静态类,所以会或上0x80其实rt_device中最重要的是传入了设备回调与操作函数指针,这些指针此时指向的是串口1的一系列操作函数。这些函数被初始化在串口1初始化的rt_hw_serial

    2022年5月12日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号