庖丁解牛Asp.net3.5控件和组件开发技术系列—事件和数据回发机制(二)
5.2.4 正确处理继承基类中控件的事件 在5.2.3.3节中讲的KingTextBox事件中,定义事件的功能语句如下:
上面代码中的 RaisePostDataChangedEvent方法首先调用了OnTextChanged,然后OnTextChanged才真正调用 TextChanged(this,e)事件。看上去有些啰唆,如果把OnTextChanged方法去掉,修改后的代码如下所示:
看上去比较简练,但这种写法对于继承此控件的控件,处理基类中事件有些限制。说明原因之前,得先说一下本节的主题,如何处理基类中继承的事件。 若要处理继承的事件,需要重写从基类继承的受保护的OnEventName方法,而不要附加委托,附加委托不能保证基类中默认的逻辑能够执行。一般情况下,重写的方法应该调用基类的OnEventName方法,以确保调用附加到事件的委托(除非不想调用这些委托)。 下面从代码角度理解上面这段含义,这里还是以OnTextChanged方法为例说明,在OnTextChanged(即上面提到的OnEventName)方法中会调用默认的事件:
如果定义了一个KingTextBoxExtend控件,并且此控件是从KingTextBox扩展而来,则我们在KingTextBoxExtend中重写OnTextChanged方法,重写后的方法如下所示:
到这里读者可能已经明白了,KingTextBoxExtend控件中的OnTextChanged能够保证基类中所有的功能,并且可以扩展,也可以干脆把base.OnTextChanged(e)这句注释掉。 但如果在TextBoxExtend中把OnTextChanged方法去掉,而直接这样写:
那么,KingTextBoxExtend控件根本没有机会重写基类中的OnTextChanged方法。即使在 KingTextBoxExtend控件中重写RaisePostDataChangedEvent事件,如果事件比较多的话,会使代码比较乱,难于控制每个事件的可执行性,最重要的是LoadPostData如果返回false,RaisePostDataEvent根本不会执行,那么这些事件也不会执行。 回到上面遗留的那个问题。您可能已经明白为什么KingTextBox控件中的RaisePostDataChangedEvent方法首先调用了OnTextChanged,然后OnTextChanged才真正调用TextChanged(this,e)事件。其实在ASP.NET 在自己的控件中一直遵守这样的规则,其中好多规则我们已经都用过很多次了,如表5-1所示。 表5-1 ASP.NET控件中提供的一些同名事件/方法匹配对 要处理的事件 要重写的方法 Init OnInit 如表5-1中说明,ASP.NET喜欢为每个事件都提供一个同名的以On前缀开头的同名方法。 重要一点: |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |