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 翻页后继续维持排序

 要想实现翻页后继续排序,实现这样的效果:  比如共 15笔记录,每页显示10条  则排序时:第一页将前10条记录排序,翻第二页时后五条再单独排序.   要注意以下几点:   1.如果数据很多,最好不...
  • CQP
  • CQP
  • 2005年12月13日 17:02
  • 917

ASP.Net 翻页后继续维持排序(转)

转自:http://dev.csdn.net/article/77/77102.shtm想实现翻页后继续排序,实现这样的效果:比如共 15笔记录,每页显示10条则排序时:第一页将前10条记录排序,翻第...
  • fzzf
  • fzzf
  • 2005年12月09日 16:26
  • 884

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

  • zgqtxwd
  • zgqtxwd
  • 2008年04月24日 07:18
  • 90

ASP.Net中DataGrid翻页后继续保持(当前排序)显示

要想实现翻页后继续排序,实现这样的效果:比如共 15笔记录,每页显示10条则排序时:第一页将前10条记录排序,翻第二页时后五条再单独排序.要注意以下几点: 1.如果数据很多,最好不要把数据集放到缓存中...
  • Yasom
  • Yasom
  • 2007年02月22日 16:36
  • 551

ASP.Net中DataGrid翻页后继续保持(当前排序)显示

2005年09月18日 00:02:00 要想实现翻页后继续排序,实现这样的效果:比如共 15笔记录,每页显示10条则排序时:第一页将前10条记录排序,翻第二页时后五条再单独排序.要注意以下几...
  • softart
  • softart
  • 2007年12月14日 11:46
  • 217

Hibernate 先排序再分页问题

DB2为例hibernate分页排序sql ORDER BY t.STATIS_DATE desc, T.AREA_CODE,T.SUBS_AREA_CODE,T.BLOCK_CODE,T.COMTY...
  • u011846594
  • u011846594
  • 2013年11月19日 10:14
  • 741

asp.net 中操作pdf档和word档

iTextSharp 下载地址:ftp://202.107.251.26/PDF%CE%C4%BC%FE%D6%C6%D7%F7%C8%AB%B9%A5%C2%D4/ Aspose.Pdf.dll ...
  • whilelie
  • whilelie
  • 2013年06月18日 17:07
  • 1845

ASP.NET 简易多选模式【解决分页时候第一页选的值翻页之后丢失问题】

效果图 对应使用    //多选项目 function choiseProject() {     var selectValue = ...
  • qq873113580
  • qq873113580
  • 2016年05月16日 15:34
  • 774

排序分页结果错乱的问题

如果order by有内容,但是不能确定唯一的位置,则sql每次查询的结果可能不一样, 如果进行分页的话,就会导致数据错乱。 分页必须保证order by 确定每行的位置,如果不能确定,可...
  • xiuzhentianting
  • xiuzhentianting
  • 2015年09月14日 18:32
  • 345

要想实现翻页后继续排序,实现这样的效果

要想实现翻页后继续排序,实现这样的效果:   比如共 15笔记录,每页显示10条   则排序时:第一页将前10条记录排序,翻第二页时后五条再单独排序.   要注意以下几点:   1.如果数据很...
  • u014660355
  • u014660355
  • 2014年04月19日 18:06
  • 228
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:ASP.NET 翻页后继续维持排序
举报原因:
原因补充:

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