c# – 调用设计器构建的事件处理程序

我目前的任务是清理,修复错误并优化 winforms中的表单(一个.cs文件中的3000行代码,它有点难看!).我已经注意到一些明显的不良做法和一些冗余调用,我可以相对容易地解决这些问题.

然而,有一个出现了很多,在我看来似乎是不好的做法,但我实际上无法用任何文档支持它.我可能完全错了.

private void datePicker_DateChanged(object sender,EventArgs e)
{
  tabControl_SelectedindexChanged(sender,e);
}

private void comboBox_SelectedindexChanged(object sender,e);
}

我首先担心的是该方法将使用发件人对象作为日期选择器或组合框,但这有关系吗?我问自己,那里的发件人对象是什么?也许这就是为什么它在那里?除非继承了类,否则我发现EventArgs本身就没用了(据我所知).

我知道tabControl_SelectedindexChanged方法中没有使用sender或EventArgs,所以代码工作正常.当一些代码被更改时,未来可能会有什么影响呢?

我应该将这些更改为3个不同的事件处理程序,这些处理程序都指向一个简单的void loadCurrentTab()方法吗?或许我应该让所有3个控件调用相同的事件处理程序,例如loadCurrentTab(sender,e)?或者只是保持原样?这很重要吗?

解决方法

Should I change these to 3 different event handlers that all point to a simple void loadCurrentTab() method?

在这种情况下,这实际上是我的偏好.这使得意图非常清晰 – 所有三个事件处理程序都路由到一组逻辑,这些逻辑(按设计)不关注发送方或EventArgs.

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...