C#知识|事件集中响应,多个按钮关联同一事件(实例练习)

哈喽,你好,我是雷工!
本节学习窗体Controls集合、控件事件的统一关联及如何优化重复代码。

01 事件集中响应

原理:就是相同的控件,可以关联同一个事件响应方法。

02 示例演示

2.1、示例功能

该示例实现窗体中选择喜欢的账号,然后弹出该账号的编号和文章数量,即对应按钮的Tag属性对应的字符串;

2.2、效果演示

在这里插入图片描述

2.3、实现步骤

2.3.1、创建窗体

首先创建窗体,在窗体上布局所需的控件,将按钮的Text属性改成对应的账号名称;
可以根据喜好修改文本和背景的颜色样式。
也可以添加效果,比如当鼠标移入时显示一种颜色,点击时显示一种颜色;

在这里插入图片描述

2.3.2、修改添加按钮的名称

在这里插入图片描述

2.3.3、修改Tag属性

Tag属性可以用来存储数据,该示例将每个账号按钮对应的编号和文章数量存储在Tag属性中;
实际项目中获取到对应数据后可以再做相应处理,此示例仅显示出来;

在这里插入图片描述

2.3.4、事件集中处理方法
代码:

//事件集中处理方法
private void btn_Click(object sender, EventArgs e)
{
    Button btn = sender as Button;
    MessageBox.Show(btn.Tag.ToString());//显示按钮Tag属性对应的字符串
}

2.3.5、事件关联
多个按钮响应同一个事件,需要通过如下代码实现事件关联;
事件关联写法1:

//多个按钮响应同一个事件,在此做事件关联(写法1)-
this.btn001.Click += new System.EventHandler(this.btn_Click);
this.btn002.Click += new System.EventHandler(this.btn_Click);
this.btn003.Click += new System.EventHandler(this.btn_Click);
this.btn004.Click += new System.EventHandler(this.btn_Click);
this.btn005.Click += new System.EventHandler(this.btn_Click);
this.btn006.Click += new System.EventHandler(this.btn_Click);
this.btn007.Click += new System.EventHandler(this.btn_Click);
this.btn008.Click += new System.EventHandler(this.btn_Click);
this.btn009.Click += new System.EventHandler(this.btn_Click);
this.btn010.Click += new System.EventHandler(this.btn_Click);
this.btn011.Click += new System.EventHandler(this.btn_Click);
this.btn012.Click += new System.EventHandler(this.btn_Click);

如上写法1比较容易理解,即将每个按钮都关联2.3.4所示的时间集中处理方法;
该写法虽然也能实现要实现的效果,但是较重复,本例为12个按钮关联同一事件,实际开发中如果遇到几十上百个按钮关联同一事件的话,按上方写法就比较麻烦了,所以可以通过如下写法优化写法1的代码:

事件关联写法2:

//多个按钮响应同一个事件,在此做事件关联(写法2)
foreach (Control item in this.Controls)
{
    if(item is Button)
    {
        Button btn = item as Button;
        if(btn.Tag.ToString()!="save")//过滤保存按钮;
        {
            btn.Click += new System.EventHandler(this.btn_Click);
        }
    }
}

写法2相比写法1明显高级很多,当一个窗体有上百个按钮时,也不用修改代码,不仅看起来简洁,维护起来也比较方便。

2.4、后记

以上为学习事件集中使用方法的一个小的练习示例,有同样在学习C#的小伙伴也可以尝试下。

  • 13
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雷工笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值