zoukankan      html  css  js  c++  java
  • C# WinForm中实现CheckBox全选反选功能

        今天一群里有人问到这个功能,其实应该挺简单,但提问题的人问题的出发点并没有描述清楚。因此,一个简简单单的需求,就引起了群内热烈的讨论。下面看看这个功能如何去实现,先上效果:

    下面直接上代码,请不要在意控件的名称以及Text属性:

       public Form6()
            {
                InitializeComponent();
                foreach (CheckBox ck in groupBox1.Controls)
                {
                     ck.CheckedChanged += Ck_CheckedChanged;
                }
            }
            private void checkBox1_Click(object sender, EventArgs e)
            {
                if (checkBox1.CheckState == CheckState.Checked)
                {
                    foreach (CheckBox ck in groupBox1.Controls)
                        ck.Checked = true;
                    checkBox1.Text = "反选";
                }
                else
                {
                    foreach (CheckBox ck in groupBox1.Controls)
                        ck.Checked = false;
                    checkBox1.Text = "全选";
                }
            }
    
            private void Ck_CheckedChanged(object sender, EventArgs e)
            {
                CheckBox c = sender as CheckBox;
                if (c.Checked == true)
                {
                    foreach (CheckBox ch in groupBox1.Controls)
                    {
                        if (ch.Checked == false)
                            return;
                    }
                    checkBox1.Checked = true;
                    checkBox1.Text = "反选";
                }
                else
                {
                    checkBox1.Checked = false;
                    checkBox1.Text = "全选";
                }
            }

    接下来要说的是,关于全选CheckBox事件的选取。最初,该同学提的问题是:有没有遇到过按钮点击没反应?但随着群里大家一人一嘴的提示,该同学渐渐把自己的需求给提出来了,他的代码是用“全选”CheckBox的CheckChanged事件中去修改“子选项”里面的6个CheckBox选中状态。然而,他又想到:如果不是点“全选”CheckBox,而是下面6个CheckBox挨个点,上面那个全选的状态怎么改。于是该同学又给下面六个CheckBox分别注册了CheckChanged事件,去判断并修改全选CheckBox的状态。最终,导致了他所谓的事件嵌套,跳不出来了。

    其实放弃使用全选的CheckChanged事件,选用Click事件就可以解决掉全选的两个Check属性更改的来源:1是来自自己的点击更改状态,2.是来自子选项中所有checkbox都选中,间接导致的全选。没有总结,仅作记录。

  • 相关阅读:
    传参总结
    装mongondb数据库
    es6的几种写法
    在github上搭建自己的主页
    云主机,虚拟主机,VPS
    TDD vs. BDD
    流量统计分析软件比较
    深入浅出Node js 读书笔记 思维导图
    浏览器的工作原理解析
    开源搜索引擎的比较
  • 原文地址:https://www.cnblogs.com/gxwang/p/6085718.html
Copyright © 2011-2022 走看看