上一篇:ASP.NET中随机数生成及应用 >>
ASP.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) { //异常 } } |
|
编辑推荐:ASP.NET初学者入门最佳实践 |
下一篇:服务器市场IBM领跑 Window系统夺冠 >>
相关文章:
- · IE再现安全漏洞 XP SP2易受远程攻击
- · 实例分析 利用微软漏洞提升电脑控制权限
- · 识别常见Web应用安全漏洞 有效防止入侵
- · 杜绝入侵:八大法则防范ASP网站漏洞
- · 思科交换机如何防范典型欺骗和攻击(图)
- · GFI在邮件内容过滤软件中增加新杀毒引擎
- · 雅虎邮箱爆脚本攻击漏洞 所幸无用户遭袭
- · Skype出现严重安全漏洞 影响两大系统
- · 甲骨文与MySQL谈判 收购矛头指向开源
- · Oracle表示可能会推出自有Linux版本
- · 最新的黑客技术:详解XSS跨站脚本攻击
- · WMF漏洞木马呈蔓延之势 春节需重点防范
- · 综述:2006搜索市场谁主沉浮
- · 欧洲研发Google杀手多媒体搜索开发
- · Oracle加入Grails开源计划
- · Oracle发布密码工具补默认密码漏洞
- · 探讨Oracle数据库的数据导入方法
- · Oracle9i Data Guard的灾难防护
- · Oracle JDeveloper10.1.3预览版发布
- · Oracle收购Siebel后的六大猜想
- · 破解Oracle中国高层频繁变动之谜
- · 数据库引擎被甲骨文操控 MySQL另谋后台
- · MySQL获美政府合同 开源跻身五角大楼
- · Oracle推免费XE版 和微软SQL针锋相对
- · 浅议Oracle中的进制转换
- · SQL Server日志文件丢失的恢复方法
- · 微软9月推VS2005及新版SQL Server
- · 编写安全的SQL Server扩展存储过程
- · 最新版Firefox上线 修正数个安全缺陷
- · Oracle数据库密码文件的使用与维护
- · WinCE下用C++实现掌上电脑遥控TV
- · 利用Visual C#编程模拟鼠标操作
- · Visual C#中用WMI编写网络程序
- · Visual C#中用WMI获取远程计算机信息
- · Visual C#中用WMI控制远程计算机
- · MySpace成获利工具 第三方推广工具出炉
- · JavaOne 2006 不容错过的十大看点
- · 从Java应用程序动态生成PDF文件
