经常遇到这样的问题,就是在DataGrid中删除了几条记录后,总页数已经改变,但当前所在的页并没有变,这时很有可能出现所在页小于总页数的可能,于会得到一个错误:当前页数不能小于0且不能大于总页数。

这个问题往往在设计时被忽略,而且在测试时也很容易忽略掉,因为如果只是一条一条的删除记录,那么在最后一页上只有一条记录,以及正好删除这条记录的机率很小,所以可能被忽略掉。如果这样,可以在删除记录的代码后添加这样语句子防止错误:
如何解决DataGrid中删除记录后分页错误            if(this.DataGrid1.CurrentPageIndex>0&&e.Item.ItemIndex==0)
如何解决DataGrid中删除记录后分页错误            {
如何解决DataGrid中删除记录后分页错误                this.DataGrid1.CurrentPageIndex
--;
如何解决DataGrid中删除记录后分页错误            }
上面条的条件正好是最后一页只有一条且要删除的。。。。

还有一种情况,就是在一页中一次删除了多条记录,这时候就要记录删除的总数量,并计算总页数以及当前页数用来区分是否要回一页。
如何解决DataGrid中删除记录后分页错误        private void LinkButton1_Click(object sender, System.EventArgs e)
如何解决DataGrid中删除记录后分页错误        {
如何解决DataGrid中删除记录后分页错误            CheckBox m_checkBox;
如何解决DataGrid中删除记录后分页错误            
int m_deleted        = 0;
如何解决DataGrid中删除记录后分页错误            foreach(DataGridItem m_record in DataGrid1.Items)
如何解决DataGrid中删除记录后分页错误            {
如何解决DataGrid中删除记录后分页错误                m_checkBox        
= m_record.Cells[0].Controls[1as CheckBox;
如何解决DataGrid中删除记录后分页错误                
long m_mailID    =0;
如何解决DataGrid中删除记录后分页错误                
if(m_checkBox!=null&&m_checkBox.Checked)
如何解决DataGrid中删除记录后分页错误                {
如何解决DataGrid中删除记录后分页错误                    m_mailID    
= Convert.ToInt64(DataGrid1.DataKeys[m_record.ItemIndex]);
如何解决DataGrid中删除记录后分页错误                    WaveMessages.DeleteMessagesByID(m_mailID);
如何解决DataGrid中删除记录后分页错误                    m_deleted
++;
如何解决DataGrid中删除记录后分页错误                }
如何解决DataGrid中删除记录后分页错误            }
如何解决DataGrid中删除记录后分页错误            
if((this.DataGrid1.Items.Count-m_deleted)/this.DataGrid1.PageSize<=this.DataGrid1.CurrentPageIndex)
如何解决DataGrid中删除记录后分页错误            {
如何解决DataGrid中删除记录后分页错误                
if(this.DataGrid1.CurrentPageIndex>0) this.DataGrid1.CurrentPageIndex--;
如何解决DataGrid中删除记录后分页错误            }
如何解决DataGrid中删除记录后分页错误            this.LoadMessagesData();
如何解决DataGrid中删除记录后分页错误        }
如何解决DataGrid中删除记录后分页错误
其中最后两个IF就是用来判断是否满足条件并回滚一页。

相关文章:

  • 2022-01-12
  • 2021-05-16
  • 2022-12-23
  • 2021-08-08
  • 2021-07-06
  • 2022-12-23
  • 2021-12-24
  • 2021-09-27
猜你喜欢
  • 2022-02-09
  • 2021-06-16
  • 2021-11-20
  • 2021-06-06
  • 2021-11-21
  • 2021-05-18
相关资源
相似解决方案