这篇文章主要介绍了C#TabControl控件中TabPage选项卡切换时的触发事件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
TabControl控件中TabPage选项卡切换时的触发事件
选项卡切换触发的是TabControl控件的SelectedIndexChanged事件。
当TabControl控件的任何一个TabPage被点击或选择,即发生SelectedIndexChanged事件事件。
代码如下:
private void tabControl1_SelectedIndexChanged(object sender, EventArgs e)
{
if (tabControl1.SelectedIndex == 0)//也可以判断tabControl1.SelectedTab.Text的值
{
//执行相应的操作
tabPageSubject.Parent = tabControlExtract;//显示
}
else if (tabControl1.SelectedIndex == 1)
{
//执行相应的操作
tabPageSubject.Parent = null; //隐藏选项卡tabPageSubject
}
}
C#选项卡TabControl控件隐藏执行选项卡的方式
如下图窗体:
如果我们想要隐藏tabPage1的话,我们该怎么做。
首先,tabControl控件由若干个tabPage成员组成。而这些tabPage成员的属性中并没有visable属性来控制它是否隐藏,那么怎么来实现隐藏呢?
首先,打开From的代码生成器:
翻到最下面我们可以看到如下几行代码。
这说明了tabPage实际上是个类。那么我们便可以正对具体的tabPage1/tabPage2/tabPage3进行操作。选项卡隐藏一般不会再tabControl上。
查看TabPage类的定义如下:
从上面的定义我们看了,有一个Visible的属性。也许和选项卡的隐藏有关。虽然Visible官方说明此成员对控件无意义。
但是经过探索,发现他还是可以用的如下:
我们在tabPage1放一个Button控件便于观察。
将隐藏和显示两个按钮编写Click时间如下:
经过试验可知,Visble属性还是有效果的,只不过效果与我们想要的不太一样。
当点击隐藏按钮时如下:Button依靠的容器消失了。但是tabPage选项卡还在!!!
当我们点击显示按钮时如下:Button与其依符的容器又显示出来了!!!
那么有没有其他办法呢?
综合网上诸多的办法,有一种比较方便就是利用TabPage类中的Parent属性设置TabPage成员依靠的父类容器即可。
具体实现如下:
利用Parent属性能够实现选项卡隐藏与显示。
状态如下:
那么为什么设置Parent属性就能够实现隐藏呢?
经过追踪发现TabPage的Parent属性实际在继承链中的Control类中。
换言之Parent是Control类的属性。TabPage类是继承Control类的。而Parent属性的解释如下:
Parent属性是控件的父容器。基本上每个控件都有个父容器。这是他们的依附的区域。如果父容器为空的话,控件必然无法依附,自然也就不能显示出来了。
窗体From是没有Parent父容器属性的,因为它是最底层的容器!!!
由于每个控件都有Parent,同理我们可以通过Parent属性来控制任意控件的显示与否。
如下,我们可以通过设置“显示”按钮的Parent属性来设置隐藏。
如下:
当隐藏按钮按下的时候就设置显示按钮的父容器为空。
下面试验一下:
如下,设置成功!!
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持织梦云。
本文标题为:C# TabControl控件中TabPage选项卡切换时的触发事件问题


基础教程推荐
- c# – USING块在网站与Windows窗体中的行为不同 2023-09-20
- Unity 如何获取鼠标停留位置下的物体 2023-04-10
- Unity shader实现高斯模糊效果 2023-01-16
- C#中 Json 序列化去掉null值的方法 2022-11-18
- C# 解析XML和反序列化的示例 2023-04-14
- C#通过标签软件Bartender的ZPL命令打印条码 2023-05-16
- C#调用摄像头实现拍照功能的示例代码 2023-03-09
- C#中的Linq to JSON操作详解 2023-06-08
- 实例详解C#实现http不同方法的请求 2022-12-26
- C#获取指定目录下某种格式文件集并备份到指定文件夹 2023-05-30