ASP.NET 翻页后继续维持排序

转载 2007年09月29日 22:07:00

要想实现翻页后继续排序,实现这样的效果:
  
    比如共 15笔记录,每页显示10条
  
    则排序时:第一页将前10条记录排序,翻第二页时后五条再单独排序.
  
    要注意以下几点:
  
    1.如果数据很多,最好不要把数据集放到缓存中(viewstate),影响性能
  
    2. ViewState中存放上次是哪个e.expression并且存放此e.expression是升序还是降序
  
    示例如下:
  
    1.现有的排序事件是这样写的,这个是点击上面排序标题时用:
  
  private void grdProjTrace_SortCommand(object source, DataGridSortCommandEventArgs e)
  {
   this.grdProjTrace.CurrentPageIndex = 0;
   DataView dv = 得到数据代码;
   string strSort = "";
   string strOrder ="";//排序方式。0,降序,1升序
   if(ViewState["SortExpresstion"] != null)
   {
    strSort = ViewState["SortExpresstion"].ToString();
    strSort = strSort.Substring(0,strSort.Length -1);
    strOrder = ViewState["SortExpresstion"].ToString();
    strOrder = strOrder.Substring(strOrder.Length -1);
   }
   if(e.SortExpression == "CustomerName")
   {
    if(strSort != "CustomerName")
    {
     this.ViewState["SortExpresstion"] = ustomerName0";
     dv.Sort = "CustomerName DESC";
    }
    else
    {
     if(strOrder == "0")
     {
      this.ViewState["SortExpresstion"] = "CustomerName1";
      dv.Sort = "CustomerName ASC";
     }
     else
     {
      this.ViewState["SortExpresstion"] = "CustomerName0";
      dv.Sort = "CustomerName DESC";
     }
    }
   }
   if(e.SortExpression == "fullName")
   {
    if(strSort != "fullName")
    {
     this.ViewState["SortExpresstion"] = "fullName0";
     dv.Sort = "fullName DESC";
    }
    else
    {
     if(strOrder == "0")
     {
      this.ViewState["SortExpresstion"] = "fullName1";
      dv.Sort = "fullName ASC";
     }
     else
     {
      this.ViewState["SortExpresstion"] = "fullName0";
      dv.Sort = "fullName DESC";
     }
    }
   }
   this.grdProjTrace.DataSource = dv;
   this.grdProjTrace.DataBind();

 }

2.下面这个方法是自己写的,翻页事件中调用。
  
  private void ChangePageDataBind()
  {
   DataView dv = 得到数据代码;
   string strSort = "";
   string strOrder ="";//排序方式。0,降序,1升序
   if(ViewState["SortExpresstion"] != null)
   {
    strSort = ViewState["SortExpresstion"].ToString();
    strSort = strSort.Substring(0,strSort.Length -1);
    strOrder = ViewState["SortExpresstion"].ToString();
    strOrder = strOrder.Substring(strOrder.Length -1);
   }
   if(this.ViewState["SortExpresstion"] != null)
   {
    if(strSort == "CustomerName")
    {
     if(strOrder == "1")
     {
      this.ViewState["SortExpresstion"] = "CustomerName1";
      dv.Sort = "CustomerName ASC";
     }
     else
     {
      this.ViewState["SortExpresstion"] = "CustomerName0";
      dv.Sort = "CustomerName DESC";
     }
    }
   }
   if(this.ViewState["SortExpresstion"] != null)
   {
    if(strSort == "fullName")
    {
     if(strOrder == "1")
     {
      this.ViewState["SortExpresstion"] = "fullName1";
      dv.Sort = "fullName ASC";
     }
     else
     {
      this.ViewState["SortExpresstion"] = "fullName0";
      dv.Sort = "fullName DESC";
     }
    }
   }
   this.grdProjTrace.DataSource = dv;
   this.grdProjTrace.DataBind();
  }
  
    上面两方法只要修改要排序的字段名,就可以直接调用了.
  
    1、方法很简单实用,这里就不说了。
  
    2、方法是这样用的:
  
  private void grdProjTrace_PageIndexChanged(object source, DataGridPageChangedEventArgs e)
  {
   try
   {
    try
    {
     this.grdProjTrace.CurrentPageIndex = e.NewPageIndex;
    }
    catch
    {
     this.grdProjTrace.CurrentPageIndex = 0;
    }
  
    this.ChangePageDataBind();
   }
   catch(System.Exception errWS)
   {
    //异常
   }
  } 

  } 
 

ASP.Net 翻页后继续维持排序.doc

  • 2007年09月05日 16:28
  • 29KB
  • 下载

ASP.NET一个翻页控件

  • 2006年02月23日 09:05
  • 20KB
  • 下载

ASP.NET中大量数据的分页、排序与过滤

1、背景 在ASP.NET中通常是用GridView显示数据,然而如果要显示大量数据,一次性的取得所有的数据d的方法指定是不行的。 2、解决方法 在分页的时候请求当页的数据,排序的时候请...

浅谈Asp.Net分页与排序技术

  • 2008年11月10日 20:58
  • 242KB
  • 下载

asp.net中对DataTable数据进行排序、检索、合并、分页、统计

一、排序 1 获取DataTable的默认视图 2 对视图设置排序表达式 3 用排序后的视图导出的新DataTable替换就DataTable (Asc升序可省略,多列排序用","隔开) ...

asp.net GridView无代码分页排序等 72般绝技

把gridview的功能,整理了下,并给出了实例代码,学习gridview的朋友必看的 - GridView无代码分页排序 GridView选中,编辑,取消,删除 GridView正反双向排序 Gri...

让Asp.NET的DataGrid可排序、可选择、可分页

让Asp.NET的DataGrid可排序、可选择、可分页 DataGrid是Asp.NET中的一个重要的控件,经常我们都将DataGrid做成可分页的和可排序的,有时还需要加上选择功能。这些都是经常...

ASP.NET MVC 3.0学习系列(19)-开源控件实现表格排序和分页

概述   前几节我们学习了怎么在MVC 3.0程序里面实现一个数据表格,以及在数据表格中加入了排序、分页和筛选等功能,对于MVC视图中标记的呈现,我们的办法是在一个中通过foreach遍历数据集,...

ASP.Net MVC + Data Table 实现分页+排序

ASP.Net MVC + Data Table 实现分页+排序
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET 翻页后继续维持排序
举报原因:
原因补充:

(最多只允许输入30个字)