C# WinForm中实现CheckBox全选反选功能

发布时间:2017-3-28 4:35:57 编辑:www.fx114.net 分享查询网我要评论
本篇文章主要介绍了"C# WinForm中实现CheckBox全选反选功能 ",主要涉及到C# WinForm中实现CheckBox全选反选功能 方面的内容,对于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都选中,间接导致的全选。没有总结,仅作记录。

上一篇:POJ_3279_(dfs)(状态)
下一篇:基于Maven的Springboot+Mybatis+Druid+Swagger2+mybatis

相关文章

相关评论

本站评论功能暂时取消,后续此功能例行通知。

一、不得利用本站危害国家安全、泄露国家秘密,不得侵犯国家社会集体的和公民的合法权益,不得利用本站制作、复制和传播不法有害信息!

二、互相尊重,对自己的言论和行为负责。

好贷网好贷款