程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> .NET實例教程 >> ASP.NET 翻頁後繼續維持排序

ASP.NET 翻頁後繼續維持排序

編輯:.NET實例教程

     要想實現翻頁後繼續排序,實現這樣的效果:
  
    比如共 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)
   {
    //異常
   }
  }

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved