WPF中ListBox ListView数据翻页浏览笔记(强调:是数据翻页,非翻页动画)
ListBox和ListView在应用中,常常有需求关于每页显示固定数量的数据,然后通过Timer自动或者手动翻页操作,本文介绍到的就是该动作的实现。
一.重点
对于ListBox和ListView来讲,后台绑定的ItemSource绑定的一般都是List<T>格式,而List<T>有个方法是Take和Skip,分别意思是取List部分和跳过List部分。
取数据的格式是:List.take().Skip();
二.话不多说,实例说话(后面会附有该例子链接,仅供参考)
(1)Xaml界面上:
<StackPanel>
<ListBox Height="" ScrollViewer.VerticalScrollBarVisibility="Disabled" ItemsSource="{Binding ListShow}"></ListBox>
<Button x:Name="TurnUpButton" Content="上翻页" Click="TurnPageUp" Height="" />
<Button x:Name="TurnDownButton" Content="下翻页" Click="TurnPageDown" Height=""/>
<Button Content="自动翻页" Click="Button_Click_1" Height=""/>
</StackPanel>
ListBox是数据显示区域,三个Button的Content已写明各自功能。
(2)CS代码
public partial class MainWindow : Window
{ public ObservableCollection<string> ListShow
{
get { return (ObservableCollection<string>)GetValue(ListShowProperty); }
set { SetValue(ListShowProperty, value); }
} public List<string> NameList = new List<string>(); public MainWindow()
{
InitializeComponent();
//WPF数据绑定
this.DataContext = this;
//假数据创建
Data();
//数据显示
ContentShow();
//Timer初始化 为自动翻页做准备
TimeSet(); } private void Data()
{
for (int i = ; i < ; i++)
{
string s = "Name" + i.ToString();
NameList.Add(s);
}
} private void ContentShow()
{
ListShow = new ObservableCollection<string>(NameList.Take(PageSize * Page).Skip(PageSize * (Page - )));
if (NameList.Count % PageSize == )
{
Total = NameList.Count / PageSize;
}
else
{
Total = NameList.Count / PageSize + ;
}
TurnUpButton.Visibility = Page > ? Visibility.Visible : Visibility.Hidden;
TurnDownButton.Visibility = Page < Total ? Visibility.Visible : Visibility.Hidden;
} private void TimeSet()
{
timer = new DispatcherTimer();
timer.Interval = TimeSpan.FromSeconds();
timer.Tick += timer_Tick;
} void timer_Tick(object sender, EventArgs e)
{
if (Page < Total)
{
Page++;
ContentShow();
}
else
{
Page = ;
ContentShow();
}
} private void Button_Click_1(object sender, RoutedEventArgs e)
{
if (IsOpen == true)
{
IsOpen = false;
timer.Stop();
}
else
{
timer.Start();
IsOpen = true;
}
} private void TurnPageUp(object sender, RoutedEventArgs e)
{
Page--;
ContentShow();
} private void TurnPageDown(object sender, RoutedEventArgs e)
{
Page++;
ContentShow();
}
DispatcherTimer timer;
private bool IsOpen;
private int Page = ;
private int Total;
private int PageSize = ; public static readonly DependencyProperty ListShowProperty =
DependencyProperty.Register("ListShow", typeof(ObservableCollection<string>), typeof(MainWindow), new PropertyMetadata(new ObservableCollection<string>())); }
ListShow是Xaml的ListBox的ItemSource绑定对象,所有数据都是通过ListShow显示到界面上的。
强调一定要用ObservableCollection<T>类型,这样才能在ListShow数据发生改变后,界面自动刷新,普通List<T>赋值上去是不会刷新界面的。
Page--当前页数。PageSize--每页数据数量。Total--总页数。
ListShow = new ObservableCollection<string>(NameList.Take(PageSize * Page).Skip(PageSize * (Page - )));
Take取PageSize*Page条数据,Skip跳过(PageSize*(Page-1))条数据,实际获取的就是1页的数据,即1个PageSize。
下面两条代码是为了限制在Page在首页和尾页时,不能继续向前翻和后翻,而设置的可见不可见。
TurnUpButton.Visibility = Page > ? Visibility.Visible : Visibility.Hidden;
TurnDownButton.Visibility = Page < Total ? Visibility.Visible : Visibility.Hidden;
三.易错点
(1)timer一定要用DispatcherTimer,如果只是用Timer会因为线程问题而不能实现自动翻页。
(2)依赖属性的Register中最后面的New PropertyMedata中是new出来一个空的ObservableCollection<string>(),不是String.Empty或者Null
四.代码下载
WPF中ListBox ListView数据翻页浏览笔记(强调:是数据翻页,非翻页动画)的更多相关文章
- WPF中ListBox /ListView如何改变选中条背景颜色
适用ListBox /ListView WPF中LISTVIEW如何改变选中条背景颜色 https://www.cnblogs.com/sjqq/p/7828119.html
- WPF ItemsControl ListBox ListView比较
在进行列表信息展示时,WPF中提供多种列表可供选择.这篇博客将对WPF ItemsControl, ListBox, ListView进行比较. 相同点: 1. 这三个控件都是列表型控件,可以进行列表 ...
- WPF中ListBox的项ListBoxItem被选中的时候Background变化
使用WPF 中ListBox,点击ListBoxItem的时候,自定义它的背景色,曾经在网上找了一些方法, 不是很理想,后来在StackOverflow上找到了,贴出代码和效果图: 效果图:
- WPF中ListBox滚动时的缓动效果
原文:WPF中ListBox滚动时的缓动效果 上周工作中遇到的问题: 常规的ListBox在滚动时总是一格格的移动,感觉上很生硬. 所以想要实现类似Flash中的那种缓动的效果,使ListBox滚动时 ...
- WPF中ListBox的绑定
WPF中列表式控件派生自ItemsControl类,继承了ItemsSource属性.ItemsSource属性可以接收一个IEnumerable接口派生类的实例作为自己的值(所有可被迭代遍历的集合都 ...
- 转:WPF中ListBox的创建和多种绑定用法
先从最容易的开始演示ListBox控件的创建. Adding ListBox Items下面的代码是向ListBox控件中添加多项ListBoxItem集合.XAML代码如下:<ListBox ...
- WPF中为ListView动态绑定数据(可参考)
GridView gv = new GridView(); DataTable dt = fieldManageBLL.GetFieldManage(moduleName); for(int i=0; ...
- WPF中ListBox控件在选择模式(SelectionMode)为Single时仍然出现多个Item被选中的问题
最近在学习WPF过程中使用到了ListBox控件,在使用时遇到下面的奇怪问题: 代码如下: listBox.Items.Add("绘图"); listBox.Items.Add(& ...
- WPF中ListBox的样式设置
设置之后的效果为
随机推荐
- mySQL用代码添加表格内容 删除数据方法
通过代码对表格内容操作: 1.添加数据insert into Info values('p009','张三',1,'n001','2016-8-30 12:9:8') ; 给特定的列添加数据inser ...
- TensorFlow的序列模型代码解释(RNN、LSTM)---笔记(16)
1.学习单步的RNN:RNNCell.BasicRNNCell.BasicLSTMCell.LSTMCell.GRUCell (1)RNNCell 如果要学习TensorFlow中的RNN,第一站应该 ...
- 【双系统】windows 和 Ubuntu 双系统安装
本博客主要讲述如何在已安装windows系统的计算机上安装Ubuntu双系统,涉及系统安装和相应磁盘空间分配等问题. 所需环境: 电脑已安装windows系统 下载Ubuntu16.04系统镜像 ...
- Running to the End(Codeforces & AtCoder 百套计划)
...Reserved for the future... 仿照xxy dalao的CF&CC百套计划,做了一个Codeforces & AtCoder 百套计划,按这个速度刷下去,每 ...
- BZOJ 3744 Gty的妹子序列 (分块+树状数组+主席树)
题面传送门 题目大意:给你一个序列,多次询问,每次取出一段连续的子序列$[l,r]$,询问这段子序列的逆序对个数,强制在线 很熟悉的分块套路啊,和很多可持久化01Trie的题目类似,用分块预处理出贡献 ...
- svn版本库更新后自动同步到www
注意:www目录一定要用SVN服务器 checkout出Repositories的代码 步骤: (1)新建www根目录 mkdir -p /data/www/lehuo (2)在www根目录下检出(c ...
- python-flask-1
https://askubuntu.com/questions/244641/how-to-set-up-and-use-a-virtual-python-environment-in-ubuntu ...
- 爬虫系列(二) Chrome抓包分析
在这篇文章中,我们将尝试使用直观的网页分析工具(Chrome 开发者工具)对网页进行抓包分析,更加深入的了解网络爬虫的本质与内涵 1.测试环境 浏览器:Chrome 浏览器 浏览器版本:67.0.33 ...
- 解决HTML select控件 设置属性 disabled 后无法向后台传值的方法
大家都知道有时候修改数据的时候我们希望有一些数据是不可以修改的,通常情况下我们会将input框设置为 readonly , 但是 select 控件没有这个属性,需要使用另一个属性 disabled ...
- dev的汉化
dev汉化网上有很多介绍.自己感觉还是用ini文件,用Localization Component来的简单方便. 但是根据其16.1.6的demo死活出问题.原因是ini文件的编码问题.转换到位自然就 ...