GridView自带了数据排序功能。在设计视图下,只能对GridView的排序数据列和排序方向进行静态设置。在后台程序中,则需要用Attributes方式对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 排序相关推荐

  1. gridview排序加箭头(二)

    用gridview排序的时候,在.NET里是不能被标注的,下面提供如下方法:主要是显示的时候进行了下判断,然后进行不同的排序,这样就给这个gridview加上了排序的箭头,有意思的是<font ...

  2. asp.net中GridView排序的手动实现

    GridView自带了数据排序功能.在设计视图下,只能对GridView的排序数据列和排序方向进行静态设置.如果要自己实现排序功能,在后台程序中,则需要用Attributes方式对GridView的这 ...

  3. [转]无刷新的ASP.NET AJAX GRIDVIEW排序

    有幸看到一个无刷新的AJAX GRIDVIEW排序效果,感觉不错,代码也简单,方便!特奉上来给各位博友参考! 下载源码 本文来源:http://www.cnblogs.com/witer666/arc ...

  4. GRIDVIEW排序 动态实现和静态实现

    用了GRIDVIEW一段时间,发现很多人都在问GRIDVIEW的排序功能,有些朋友在我的QQ群(13536330)里面问我,我觉得有三种方法可以实现,但本文我只讲两种,相信可以满足大家的需要了吧. 1 ...

  5. ASP.NET 2.0中GRIDVIEW排序

    在 headertemplate中加一张UP.GIF和DOWN.GIF(就是升序,倒序的示意图) %@ Page Language="C#" %> <!DOCTYPE ...

  6. GridView排序404以及SortExpression字符长度限制

    今天在做一个统计页面时,因为子查询等某些原因,在进行排序操作时,不能给SortExpression直接复制列名,而是赋值子查询语句,结果在测试时,点击部分列,会直接报错404,debug调试时也不会走 ...

  7. gridview的sort_GridView实现自动排序带上下箭头

    GridView排序 ForeColor="#333333" GridLines="None" AllowSorting="True" On ...

  8. GridView 自动排序

    GridView自动排序 GridView自带了数据排序功能.在设计视图下,只能对GridView的排序数据列和排序方向进行静态设置.在后台程序中,则需要用Attributes方式对GridView的 ...

  9. gridview、datalist、repeater、FormView、DetailsView的区别详解

    1. GridView 控件 GridView 控件用于显示表中的数据.通过使用 GridView 控件,您可以显示.编辑.删除.排序和翻阅多种不同的数据源(包括数据库.XML 文件和公开数据的业务对 ...

  10. asp.net学习之GridView

    显示表格数据是软件开发中的一个周期性任务.ASP.NET 提供了许多工具来在网格中显示表格数据,例如 GridView 控件.通过使用 GridView 控件,您可以显示.编辑和删除多种不同的数据源( ...

最新文章

  1. SQL查询结果集对注入的影响及利用
  2. 回溯 Rust 2020:正成为最受欢迎的编程语言
  3. 可观察性驱动开发,探索未知之地
  4. 熊猫“大虾”-03/07/2011开始修炼
  5. 所以一切都是有套路的,按照套路出牌是最合适的方式。
  6. Linux 中 的 vi 编辑模式 直接对文件进行修改~
  7. moba的m是什么意思_moba游戏是什么
  8. 网络新手ip隐藏器_什么是高防IP,高防IP原理是什么
  9. iOS DevCamp Android DevCamp 课程集锦 为最喜爱的课程投票 获得CSDN社区会员专享特惠票...
  10. php如何去除文件扩展名,php怎样去除文件后缀名
  11. 2019/7/31随笔
  12. 苹果开发者账户协议更新
  13. Git 修改历史 commit 提交信息
  14. hell脚本案例(一):常见运维面试题
  15. CPU架构之ARM优化
  16. Dancing Line、网易蜗牛读书——创新性分析
  17. IT外企那点儿事(13): 你总是在画饼吗?
  18. HDOJ 1218 Blurred Vision (水题)
  19. 读《与赛博空间共存》
  20. 钉钉机器人推送表格图片

热门文章

  1. 地理可视化绘制——中国分省多年GDP绘制
  2. Word XP 中目录的编制方法,Word XP 功能键使用大全
  3. 02333软件工程_202008_试卷+答案
  4. 一个IT农民工分享互联网巨头公司面试流程
  5. 自动化系统扫描数字和文本OCR条形码控件字体
  6. 计算机程序员crc算法,CRC-8校验原理及软件实现
  7. UltraEdit编辑器+注册机(windows版)让数据处理更简单
  8. maven镜像仓库的配置
  9. 国内比较有名的maven镜像
  10. 最好的磁盘管理工具Acronis Disk Director Suite 10.0英文原版 + 注册机 + 使用图文介绍