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

王朝asp·作者佚名  2008-05-19
宽屏版  字体: |||超大  

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)

{

//异常

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有