zoukankan
html css js c++ java
如何解决DataGrid中删除记录后分页错误
经常遇到这样的问题,就是在DataGrid中删除了几条记录后,总页数已经改变,但当前所在的页并没有变,这时很有可能出现所在页小于总页数的可能,于会得到一个错误:当前页数不能小于0且不能大于总页数。
这个问题往往在设计时被忽略,而且在测试时也很容易忽略掉,因为如果只是一条一条的删除记录,那么在最后一页上只有一条记录,以及正好删除这条记录的机率很小,所以可能被忽略掉。如果这样,可以在删除记录的代码后添加这样语句子防止错误:
if
(this.DataGrid1.CurrentPageIndex
>
0
&&
e.Item.ItemIndex
==
0
)
{
this.DataGrid1.CurrentPageIndex
--
;
}
上面条的条件正好是最后一页只有一条且要删除的。。。。
还有一种情况,就是在一页中一次删除了多条记录,这时候就要记录删除的总数量,并计算总页数以及当前页数用来区分是否要回一页。
private
void LinkButton1_Click(
object
sender, System.EventArgs e)
{
CheckBox m_checkBox;
int
m_deleted
=
0
;
foreach(DataGridItem m_record in DataGrid1.Items)
{
m_checkBox
=
m_record.Cells[
0
].Controls[
1
]
as
CheckBox;
long
m_mailID
=
0
;
if
(m_checkBox!
=
null
&&
m_checkBox.Checked)
{
m_mailID
=
Convert.ToInt64(DataGrid1.DataKeys[m_record.ItemIndex]);
WaveMessages.DeleteMessagesByID(m_mailID);
m_deleted
++
;
}
}
if
((this.DataGrid1.Items.Count
-
m_deleted)
/
this.DataGrid1.PageSize
<=
this.DataGrid1.CurrentPageIndex)
{
if
(this.DataGrid1.CurrentPageIndex
>
0
) this.DataGrid1.CurrentPageIndex
--
;
}
this.LoadMessagesData();
}
其中最后两个IF就是用来判断是否满足条件并回滚一页。
================================
/\_/\
(=^o^=)
Wu.Country@侠缘
(~)@(~)
一辈子,用心做一件事!
--------------------------------
学而不思则罔,思而不学则怠!
================================
查看全文
相关阅读:
Mysql_大字段问题Row size too large.....not counting BLOBs, is 8126.
Pycharm快捷键设置(鼠标滚动控制字体大小)
python实现将base64编码的图片下载到本地
[CentOS_7.4]Linux编译安装ffmpeg
contenOs7
文本特征提取方法研究
Mahout中相似度计算方法介绍
基于Mahout的电影推荐系统
向Python女神推荐这些年我追过的经典书籍
Mahout推荐算法API详解
原文地址:https://www.cnblogs.com/WuCountry/p/334518.html
最新文章
ES6知识
vue-quill-editor he el-upload实现富文本编译器上传图片及文字功能
前端(vue)文件上传
Vuex 的基本使用
Vue项目优化
ajax跨域方法
原生ajax发送数据,以及不用的方法发送
mysql学习笔记--基本类型
meta标签作用总结
react使用脚手架开发
热门文章
vue搭建多页面开发环境
react环境搭建
java抽象类
java特性---多态
java引用类型转换
正则表达式--反向引用
微信公众号项目总结--加快开发速度和调试效率
mysql自增长主键,删除数据后,将主键顺序重新排序
selenium+Headless Chrome实现不弹出浏览器自动化登录
selenium如何屏蔽谷歌浏览器弹出的通知
Copyright © 2011-2022 走看看