基于WPF自定义分页控件的示例代码

 更新时间:2025年07月09日 08:26:03   作者:孤独成派  
在桌面应用程序开发中,特别是使用WPF框架时,数据展示和用户交互的优化至关重要,本文将介绍两种不同的分页控件的实现方式,有需要的可以了解下

前言

在桌面应用程序开发中,特别是使用WPF框架时,数据展示和用户交互的优化至关重要。当处理大量数据时,如何有效地进行分页显示成为了一个关键问题。

本文将介绍两种不同的分页控件——通用分页控件 Pager 和自动分页控件 ListPager 的实现方式,并提供相应的XAML和C#代码示例。

分页效果

通用分页控件 Pager

XAML 示例

<DockPanel Margin="10">
    <pp:Pager x:Name="pager" DockPanel.Dock="Top" Margin="0 10">
        <ComboBox x:Name="combo" Padding="6 0" SelectedIndex="0" BorderBrush="#D9D9D9" Foreground="#333" pp:BorderElement.CornerRadius="4" Margin="6 0"
        DisplayMemberPath="Value" SelectedValuePath="Key" SelectedValue="{Binding PageSize,ElementName=pager}" />
    </pp:Pager>
    <ListBox x:Name="list" />
</DockPanel>

该XAML定义了页面顶部的一个 Pager 控件,其中包含一个下拉框用于选择每页显示的条目数。下方是一个 ListBox 用于展示分页后的数据。

后台代码

public PagerView()
{
    InitializeComponent();

    var dic = new Dictionary<Int32, String>
    {
        [10] = "10条/页",
        [20] = "20条/页",
        [30] = "30条/页",
        [40] = "40条/页",
    };

    combo.ItemsSource = dic;
    combo.SelectedValue = 10;

    pager.PageIndexChanged += OnPageIndexChanged;
    pager.TotalCount = datas.Count();
}

private void OnPageIndexChanged(Object sender, EventArgs e)
{
    list.ItemsSource = datas.Skip((pager.PageIndex - 1) * pager.PageSize).Take(pager.PageSize);
}

private IEnumerable<Int32> datas = Enumerable.Range(1, 999);

这段段代码实现了分页逻辑,监听 PageIndexChanged 事件来刷新列表数据。

样式模板

<Style TargetType="{x:Type ctrls:Pager}">
    <!-- 省略样式细节 -->
</Style>

通过自定义样式模板可以调整 Pager 控件的外观,如页码按钮、跳转输入框等。

自动分页控件 ListPager

XAML 示例

<DockPanel Margin="10">
    <pp:ListPager x:Name="pager" DockPanel.Dock="Top" Margin="0 10">
        <ComboBox x:Name="combo" Padding="6 0" SelectedIndex="0" BorderBrush="#D9D9D9" Foreground="#333" pp:BorderElement.CornerRadius="4" Margin="6 0"
                  DisplayMemberPath="Value" SelectedValuePath="Key" SelectedValue="{Binding PageSize,ElementName=pager}" />
    </pp:ListPager>
    <ListBox x:Name="list" ItemsSource="{Binding DisplaySource,ElementName=pager}" />
</DockPanel>

ListPager 控件简化了分页流程,只需设置数据源即可自动完成分页。

后台代码

public ListPagerView()
{
    InitializeComponent();

    var dic = new Dictionary<Int32, String>
    {
        [10] = "10条/页",
        [20] = "20条/页",
        [30] = "30条/页",
        [40] = "40条/页",
    };

    combo.ItemsSource = dic;
    combo.SelectedValue = 10;

    pager.Source = Enumerable.Range(1, 999);
}

相比 PagerListPager 更加便捷,它直接接收全部数据并根据页面大小自动处理分页逻辑。

项目源码

GitHub:github.com/LowPlayer/PP.Wpf

总结

不管是 Pager 还是 ListPager,它们都提供了灵活且强大的分页解决方案,适用于不同的场景需求。Pager 提供了更多的手动控制选项,适合需要定制化分页逻辑的应用;而 ListPager 则简化了开发者的负担,特别适合那些能够一次性获取所有数据的情况。

这些控件不仅提升了用户体验,也提高了数据展示的效率。对于开发来说,理解并合理选用这两种分页控件,可以极大地提升应用的性能和易用性。

到此这篇关于基于WPF自定义分页控件的示例代码的文章就介绍到这了,更多相关WPF分页内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • C#制作网站挂机程序的实现示例

    C#制作网站挂机程序的实现示例

    本文主要介绍了C#制作网站挂机程序,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • C# 当前系统时间获取及时间格式详解

    C# 当前系统时间获取及时间格式详解

    这篇文章主要介绍了C# 当前系统时间获取及时间格式详解的相关资料,这里提供代码实例,帮助大家学习参考,需要的朋友可以参考下
    2016-12-12
  • 在C#中读取CPU、硬盘和内存温度的完整代码

    在C#中读取CPU、硬盘和内存温度的完整代码

    系统监控工具或性能分析应用时,实时获取硬件信息(如 CPU、硬盘和内存的温度)是一个常见且重要的需求,本文将详细介绍如何在 C# 项目中集成并使用 Open Hardware Monitor 库,以实现对 CPU、硬盘以及内存温度的监控,需要的朋友可以参考下
    2025-06-06
  • C#格式化数字字符串的方法

    C#格式化数字字符串的方法

    这篇文章主要为大家详细介绍了C#格式化数字字符串的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • C#中overrid和new修饰符有什么不同

    C#中overrid和new修饰符有什么不同

    在C#的继承中尝尝会用到相关的修饰词:override和new。这两个修饰符都可以在新的子类中,重写同名的父类方法。下面通过本文给大家介绍C#中overrid和new修饰符的区别,感兴趣的朋友一起看看吧
    2018-02-02
  • Unity 实现框选游戏战斗单位的思路详解

    Unity 实现框选游戏战斗单位的思路详解

    这篇文章主要介绍了Unity 如何实现框选游戏战斗单位,本文简单介绍如何实现即时战略游戏中框选战斗单位的功能,需要的朋友可以参考下
    2022-12-12
  • C# Volatile的具体使用

    C# Volatile的具体使用

    本文主要介绍了C# Volatile的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • C#动态代码生成控件后其他事件不能获取该控件值的解决方法

    C#动态代码生成控件后其他事件不能获取该控件值的解决方法

    这篇文章主要给大家介绍了关于C#动态代码生成控件后其他事件不能获取该控件值的解决方法,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07
  • C#难点逐个击破(1):ref参数传递

    C#难点逐个击破(1):ref参数传递

    一般情况,方法的参数传递是通过值进行传递的,另一种情况是引用传递,大家可以参考下。
    2010-02-02
  • C#中Random.Next方法的使用小结

    C#中Random.Next方法的使用小结

    在C#中,Random.Next()方法用于生成一个随机整数,本文主要介绍了C#中Random.Next方法的使用小结,具有一定的参考价值,感兴趣的可以了解一下
    2024-01-01

最新评论