wpf之TabControl

前言

在开发wpf程序过程中有时候控件比较多,导致一个页面显示不全,这时候就要分页显示,这时可以利用TabControl来实现分页显示功能。

1、普通TabControl

每一个TabItem都是一个标签容器,Header属性的值是容器显示的标签文字,下面的代码中有三个容器,容器显示的标签文字分别为"1"、"2"、"3",,每个容器里面都可以添加无数个控件。

csharp 复制代码
<TabControl >
            <TabItem  Header=" 1">
                <StackPanel >
                    <TextBlock Text="第一项"/>
                </StackPanel >
            </TabItem>
            <TabItem  Header=" 2">
                <StackPanel >
                    <TextBlock Text="第二项"/>
                </StackPanel >
            </TabItem>
            <TabItem  Header=" 3">
                <StackPanel >
                    <TextBlock Text="第三项"/>
                </StackPanel >
            </TabItem>
        </TabControl >

2、自定义标签头的TabControl

标签头除了显示文本外,还可以以任意形式显示,比如下面的图像中标签除了文字以外还有一个红色的圆形,当然你也可以把红色圆形改成图标,这是通过设置TabItem.Header来实现,下面的代码中TabItem.Header放入一个StackPanel,然后StackPanel放入Ellipse和TextBlock

csharp 复制代码
<TabControl  >
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="首页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第一项"/>
                </StackPanel >
            </TabItem>
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="第2页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第二项"/>
                </StackPanel >
            </TabItem>
            <TabItem  >
                <TabItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Ellipse Fill="Red"   Width="16" Height="16"/>
                        <TextBlock Text="第3页" Margin="2,0,0,0"/>
                    </StackPanel>
                </TabItem.Header>
                <StackPanel >
                    <TextBlock Text="第三项"/>
                </StackPanel >
            </TabItem>
        </TabControl >

马工撰写的年入30万+C#上位机项目实战必备教程(点击下方链接即可访问文章目录)

1、《C#串口通信从入门到精通》

2、《C#与PLC通信从入门到精通 》

3、《C# Modbus通信从入门到精通》

4、《C#Socket通信从入门到精通 》

5、《C# MES通信从入门到精通》

6、《winform控件从入门到精通》

7、《C#操作MySql数据库从入门到精通》

相关推荐
rockey6272 小时前
AScript如何实现中文脚本引擎
c#·.net·script·eval·expression·function·动态脚本
我是唐青枫3 小时前
C#.NET gRPC 深入解析:Proto 定义、流式调用与服务间通信取舍
开发语言·c#·.net
unicrom_深圳市由你创科技4 小时前
做虚拟示波器这种实时波形显示的上位机,用什么语言?
c++·python·c#
昵称暂无15 小时前
.NET 高级开发 | i18n 原理、实现一个 i18n 框架
javascript·c#·.net
疯狂成瘾者5 小时前
Chroma向量数据库
开发语言·数据库·c#
我是唐青枫5 小时前
C#.NET Monitor 与 Mutex 深入解析:进程内同步、跨进程互斥与使用边界
开发语言·c#·.net
ou.cs5 小时前
c# 信号量和锁的区别
开发语言·c#
yugi9878386 小时前
C# 串口下载烧写BIN文件工具
开发语言·c#
"菠萝"7 小时前
C#知识学习-021(文字关键字)
开发语言·学习·c#
游乐码7 小时前
c#HashTable
开发语言·c#