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

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

  比如共 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) 
 { 
  //异常 
 } 
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值