我不明白扩展EventArgs是如何有用的。
public class ClickedEventArgs : EventArgs {
int x;
int y;
public ClickedEventArgs (int x, int y) {
this.x = x;
this.y = y;
}
public int X { get { return x; } }
public int Y { get { return y; } }
}
代码在上面。我怎样才能使用这种继承呢?我想学习如何从default.aspx
调用此代码博客答案 0 :(得分:12)
您是否在问为什么首先从EventArgs
派生出来是有用的?我不得不说,使用C#1它没有多大意义,因为委托转换的工作方式 - 但从C#2开始,它更明智。它允许事件处理程序在事件中注册,即使它不关心事件参数的细节。
例如:
void LogEvent(object sender, EventArgs e)
{
Console.WriteLine("Event sent from " + sender);
}
...
textArea.KeyPress += LogEvent;
即使Control.KeyPress
是KeyPressEventHandler
类型的事件,这仍然有效。 C#和.NET不介意LogEvent
的签名完全 与KeyPressEventHandler
的签名完全匹配 - 它足够兼容。
不可否认,如果我们根本没有EventArgs
(你可以只使用object
)但是给定EventArgs
类和模式,这仍然是可行的从EventArgs
派生您自己的事件参数。
答案 1 :(得分:2)
以下是您可能如何使用代码的示例:
public class MyClass () {
public event EventHandler<ClickedEventArgs> ClickedEvent = delegate {}; //Register the event
protected void SomethingWasClicked(int x, int y) {
ClickedEvent(this, new ClickedEventArgs(x,y)); //Invoke the event that is subscribed to
}
}
public class AnotherClass () {
public AnotherClass () {
MyClass mClass = new MyClass();
mClass.ClickedEvent += new EventHandler(mClass_clickedEvent);
}
protected void mClass_clickedEvent(object sender, ClickedEventArgs e) {
//Retrieve the X parameter that was passed from the MyClass instance
int x = e.X;
}
}
答案 2 :(得分:2)
这里真正重要的是,您可以稍后轻松升级您的活动,以获得更多详细信息,并且不会破坏现有的解耦侦听器。