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[1as 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就是用来判断是否满足条件并回滚一页。
  • 相关阅读:
    天天生鲜(一) 表设计
    linux 分区管理
    linux rpm包管理 yum管理
    linux命令
    linux IP 网关配置
    Django的JWT机制工作流程
    django CBV模式源码执行过程
    django 网站上传资源的显示与配置
    图片服务器的架构演进
    php获取指定目录下的所有文件列表
  • 原文地址:https://www.cnblogs.com/WuCountry/p/334518.html
Copyright © 2011-2022 走看看