gridview 排序
示例如下:
(前台)
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>无标题页</title> </head> <body> <form id="form1" runat="server"> <div> <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="4" ForeColor="#333333" GridLines="None" AllowSorting="True" OnSorting="GridView1_Sorting"> <FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> <RowStyle BackColor="#EFF3FB" /> <Columns> <asp:BoundField DataField="id" HeaderText="ID" SortExpression="id" /> <asp:BoundField DataField="name" HeaderText="NAME" SortExpression="name" /> <asp:BoundField DataField="age" HeaderText="AGE" SortExpression="age" /> </Columns> <PagerStyle BackColor="#2461BF" ForeColor="White" HorizontalAlign="Center" /> <SelectedRowStyle BackColor="#D1DDF1" Font-Bold="True" ForeColor="#333333" /> <HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" /> <EditRowStyle BackColor="#2461BF" /> <AlternatingRowStyle BackColor="White" /> </asp:GridView> </div> </form> </body> </html>
前台注意点:
需要对GridView启用AllowSorting、设置OnSorting事件,对需要排序的列设定SortExpression属性。
(后台)
using System; using System.Data; using System.Configuration; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using System.Web.UI.HtmlControls; public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { // 设定初始排序参数值 // 错误的属性设置方法:SortExpression、SortDirection均是GridView只读属性,无法直接赋值。 //this.GridView1.SortExpression = "id"; //this.GridView1.SortDirection = "ASC"; // 正确的属性设置方法 this.GridView1.Attributes.Add("SortExpression", "id"); this.GridView1.Attributes.Add("SortDirection", "ASC"); // 绑定数据源到GridView this.BindGridView(); } } /// <summary> /// GridView排序事件 /// </summary> protected void GridView1_Sorting(object sender, GridViewSortEventArgs e) { // 从事件参数获取排序数据列 string sortExpression = e.SortExpression.ToString(); // 假定为排序方向为“顺序” string sortDirection = "ASC"; // “ASC”与事件参数获取到的排序方向进行比较,进行GridView排序方向参数的修改 if (sortExpression == this.GridView1.Attributes["SortExpression"]) { //获得下一次的排序状态 sortDirection = (this.GridView1.Attributes["SortDirection"].ToString() == sortDirection ? "DESC" : "ASC"); } // 重新设定GridView排序数据列及排序方向 this.GridView1.Attributes["SortExpression"] = sortExpression; this.GridView1.Attributes["SortDirection"] = sortDirection; this.BindGridView(); } /// <summary> /// 绑定到GridView /// </summary> private void BindGridView() { // 获取GridView排序数据列及排序方向 string sortExpression = this.GridView1.Attributes["SortExpression"]; string sortDirection = this.GridView1.Attributes["SortDirection"]; // 调用业务数据获取方法 DataTable dtBind = this.getDB(); // 根据GridView排序数据列及排序方向设置显示的默认数据视图 if ((!string.IsNullOrEmpty(sortExpression)) && (!string.IsNullOrEmpty(sortDirection))) { dtBind.DefaultView.Sort = string.Format("{0} {1}", sortExpression, sortDirection); } // GridView绑定并显示数据 this.GridView1.DataSource = dtBind; this.GridView1.DataBind(); } /// <summary> /// 获取数据源的方法 /// </summary> /// <returns>数据源</returns> private DataTable getDB() { DataTable dt = new DataTable(); dt.Columns.Add("id"); dt.Columns.Add("name"); dt.Columns.Add("age"); dt.Rows.Add(new object[] { "000001", "hekui", "26" }); dt.Rows.Add(new object[] { "000002", "zhangyu", "26" }); dt.Rows.Add(new object[] { "000003", "zhukundian", "27" }); dt.Rows.Add(new object[] { "000004", "liyang", "25" }); dt.Rows.Add(new object[] { "000005", "caili", "27" }); return dt; } }
转载于:https://www.cnblogs.com/Sue_/articles/2059536.html
gridview 排序相关推荐
- gridview排序加箭头(二)
用gridview排序的时候,在.NET里是不能被标注的,下面提供如下方法:主要是显示的时候进行了下判断,然后进行不同的排序,这样就给这个gridview加上了排序的箭头,有意思的是<font ...
- asp.net中GridView排序的手动实现
GridView自带了数据排序功能.在设计视图下,只能对GridView的排序数据列和排序方向进行静态设置.如果要自己实现排序功能,在后台程序中,则需要用Attributes方式对GridView的这 ...
- [转]无刷新的ASP.NET AJAX GRIDVIEW排序
有幸看到一个无刷新的AJAX GRIDVIEW排序效果,感觉不错,代码也简单,方便!特奉上来给各位博友参考! 下载源码 本文来源:http://www.cnblogs.com/witer666/arc ...
- GRIDVIEW排序 动态实现和静态实现
用了GRIDVIEW一段时间,发现很多人都在问GRIDVIEW的排序功能,有些朋友在我的QQ群(13536330)里面问我,我觉得有三种方法可以实现,但本文我只讲两种,相信可以满足大家的需要了吧. 1 ...
- ASP.NET 2.0中GRIDVIEW排序
在 headertemplate中加一张UP.GIF和DOWN.GIF(就是升序,倒序的示意图) %@ Page Language="C#" %> <!DOCTYPE ...
- GridView排序404以及SortExpression字符长度限制
今天在做一个统计页面时,因为子查询等某些原因,在进行排序操作时,不能给SortExpression直接复制列名,而是赋值子查询语句,结果在测试时,点击部分列,会直接报错404,debug调试时也不会走 ...
- gridview的sort_GridView实现自动排序带上下箭头
GridView排序 ForeColor="#333333" GridLines="None" AllowSorting="True" On ...
- GridView 自动排序
GridView自动排序 GridView自带了数据排序功能.在设计视图下,只能对GridView的排序数据列和排序方向进行静态设置.在后台程序中,则需要用Attributes方式对GridView的 ...
- gridview、datalist、repeater、FormView、DetailsView的区别详解
1. GridView 控件 GridView 控件用于显示表中的数据.通过使用 GridView 控件,您可以显示.编辑.删除.排序和翻阅多种不同的数据源(包括数据库.XML 文件和公开数据的业务对 ...
- asp.net学习之GridView
显示表格数据是软件开发中的一个周期性任务.ASP.NET 提供了许多工具来在网格中显示表格数据,例如 GridView 控件.通过使用 GridView 控件,您可以显示.编辑和删除多种不同的数据源( ...
最新文章
- SQL查询结果集对注入的影响及利用
- 回溯 Rust 2020:正成为最受欢迎的编程语言
- 可观察性驱动开发,探索未知之地
- 熊猫“大虾”-03/07/2011开始修炼
- 所以一切都是有套路的,按照套路出牌是最合适的方式。
- Linux 中 的 vi 编辑模式 直接对文件进行修改~
- moba的m是什么意思_moba游戏是什么
- 网络新手ip隐藏器_什么是高防IP,高防IP原理是什么
- iOS DevCamp Android DevCamp 课程集锦 为最喜爱的课程投票 获得CSDN社区会员专享特惠票...
- php如何去除文件扩展名,php怎样去除文件后缀名
- 2019/7/31随笔
- 苹果开发者账户协议更新
- Git 修改历史 commit 提交信息
- hell脚本案例(一):常见运维面试题
- CPU架构之ARM优化
- Dancing Line、网易蜗牛读书——创新性分析
- IT外企那点儿事(13): 你总是在画饼吗?
- HDOJ 1218 Blurred Vision (水题)
- 读《与赛博空间共存》
- 钉钉机器人推送表格图片
热门文章
- 地理可视化绘制——中国分省多年GDP绘制
- Word XP 中目录的编制方法,Word XP 功能键使用大全
- 02333软件工程_202008_试卷+答案
- 一个IT农民工分享互联网巨头公司面试流程
- 自动化系统扫描数字和文本OCR条形码控件字体
- 计算机程序员crc算法,CRC-8校验原理及软件实现
- UltraEdit编辑器+注册机(windows版)让数据处理更简单
- maven镜像仓库的配置
- 国内比较有名的maven镜像
- 最好的磁盘管理工具Acronis Disk Director Suite 10.0英文原版 + 注册机 + 使用图文介绍