override ASP.Net2.0 GridView 多列排序,显示排序图标,分页
2007-03-13 07:45
344 查看
ASP.Net2.0 GridView 多列排序,显示排序图标,分页。
最近在使用ASP.net 2.0的GridView 控件时,发现排序与分页功能Microsoft实现的都很简单,比如排序,在点击列名的时候来触发整页的PostBack,然后排序,但是在列头上没有一个显示升序降序的图标,这会让最终用户使用时很迷惑,因为不知道是升序了还是降序了,所以今天首先解决的第一问题就是升序降序在列上显示图标,第二要解决的问题是默认GridView按列排序只能排一列的,也就是不能进行多列排序,而在实际应用中仅仅按照一列来排序是不能满足业务需求的,第三是GridView 分页问题,GridView预定义的分页页码显示,比较简单,而实际应用中,分页可能不是只显示首页,上一页,下一页,末页,或者是数字的页码那么简单,应该更需要,跳转,当前的页码,总页数等,更详尽的信息。
第一:GridView 多列排序与排序图标显示
首先我们可以新建一个类库程序,主要需要引用System.Web.Dll文件
然后新建一个类,这个类继承与GridView控件,我们只需要对部分方法进行重新即可。
我的演示的例子,采用了单列排序,如果启用多列排序,把控件的AllowMultiColumnSorting设置为True就是
多列排序。
1
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
public class WebGridView:GridView
2
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/34031c708bfe702fe82d01ff5c6593aa.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/0be121fa5b8988fbabbbc526af3b0fc0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
3
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
属性#region 属性
4
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
5
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 是否启用或者禁止多列排序
6
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
7
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
8
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("是否启用多列排序功能"),
9
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
10
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue("false"),
11
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
12
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public bool AllowMultiColumnSorting
13
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
14
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
15
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
16
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["EnableMultiColumnSorting"];
17
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? (bool)o : false);
18
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
19
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
20
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
21
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
AllowSorting = true;
22
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["EnableMultiColumnSorting"] = value;
23
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
24
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
25
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
26
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 升序时显示图标
27
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
28
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
29
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("升序时显示图标"),
30
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
31
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Editor("System.Web.UI.Design.UrlEditor", typeof(System.Drawing.Design.UITypeEditor)),
32
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue(""),
33
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
34
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
35
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public string SortAscImageUrl
36
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
37
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
38
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
39
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["SortImageAsc"];
40
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? o.ToString() : "");
41
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
42
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
43
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
44
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["SortImageAsc"] = value;
45
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
46
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
47
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
48
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 降序时显示图标
49
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
50
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
51
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("降序时显示图标"),
52
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
53
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Editor("System.Web.UI.Design.UrlEditor", typeof(System.Drawing.Design.UITypeEditor)),
54
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue(""),
55
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
56
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public string SortDescImageUrl
57
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
58
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
59
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
60
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["SortImageDesc"];
61
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? o.ToString() : "");
62
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
63
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
64
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
65
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["SortImageDesc"] = value;
66
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
67
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
68
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
69
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
重写方法#region 重写方法
70
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected override void OnSorting(GridViewSortEventArgs e)
71
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
72
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
73
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
74
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
e.SortExpression = GetSortExpression(e);
75
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
76
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
77
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
base.OnSorting(e);
78
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
79
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected override void OnRowCreated(GridViewRowEventArgs e)
80
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
81
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (e.Row.RowType == DataControlRowType.Header)
82
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
83
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (SortExpression != String.Empty)
84
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
85
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DisplaySortOrderImages(SortExpression, e.Row);
86
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
this.CreateRow(0, 0, DataControlRowType.EmptyDataRow, DataControlRowState.Normal);
87
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
88
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
89
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
base.OnRowCreated(e);
90
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
91
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
92
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
受保护的方法#region 受保护的方法
93
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
94
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 获取排序表达式
95
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
96
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected string GetSortExpression(GridViewSortEventArgs e)
97
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
98
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string[] sortColumns = null;
99
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortAttribute = SortExpression;
100
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
101
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortAttribute != String.Empty)
102
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
103
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortColumns = sortAttribute.Split(",".ToCharArray());
104
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
105
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortAttribute.IndexOf(e.SortExpression) > 0 || sortAttribute.StartsWith(e.SortExpression))
106
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
107
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortAttribute = ModifySortExpression(sortColumns, e.SortExpression);
108
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
109
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
110
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
111
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortAttribute += String.Concat(",", e.SortExpression, " ASC ");
112
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
113
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return sortAttribute.TrimStart(",".ToCharArray()).TrimEnd(",".ToCharArray());
114
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
115
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
116
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
117
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 修改排序顺序
118
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
119
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected string ModifySortExpression(string[] sortColumns, string sortExpression)
120
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
121
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string ascSortExpression = String.Concat(sortExpression, " ASC ");
122
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string descSortExpression = String.Concat(sortExpression, " DESC ");
123
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
124
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < sortColumns.Length; i++)
125
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
126
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
127
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (ascSortExpression.Equals(sortColumns[i]))
128
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
129
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortColumns[i] = descSortExpression;
130
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
131
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
132
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (descSortExpression.Equals(sortColumns[i]))
133
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
134
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Array.Clear(sortColumns, i, 1);
135
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
136
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
137
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
138
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return String.Join(",", sortColumns).Replace(",,", ",").TrimStart(",".ToCharArray());
139
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
140
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
141
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
142
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 获取当前的表达式对所选列进行排序
143
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
144
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected void SearchSortExpression(string[] sortColumns, string sortColumn, out string sortOrder, out int sortOrderNo)
145
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
146
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = "";
147
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrderNo = -1;
148
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < sortColumns.Length; i++)
149
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
150
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortColumns[i].StartsWith(sortColumn))
151
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
152
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrderNo = i + 1;
153
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
154
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
155
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = sortColumns[i].Substring(sortColumn.Length).Trim();
156
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
157
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
158
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
159
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = ((SortDirection == SortDirection.Ascending) ? "ASC" : "DESC");
160
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
161
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
162
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
163
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
164
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
165
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 绘制升序降序的图片
166
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
167
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected void DisplaySortOrderImages(string sortExpression, GridViewRow dgItem)
168
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
169
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string[] sortColumns = sortExpression.Split(",".ToCharArray());
170
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
171
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < dgItem.Cells.Count; i++)
172
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
173
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (dgItem.Cells[i].Controls.Count > 0 && dgItem.Cells[i].Controls[0] is LinkButton)
174
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
175
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortOrder;
176
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int sortOrderNo;
177
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string column = ((LinkButton)dgItem.Cells[i].Controls[0]).CommandArgument;
178
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
SearchSortExpression(sortColumns, column, out sortOrder, out sortOrderNo);
179
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortOrderNo > 0)
180
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
181
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortImgLoc = (sortOrder.Equals("ASC") ? SortAscImageUrl : SortDescImageUrl);
182
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
183
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortImgLoc != String.Empty)
184
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
185
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Image imgSortDirection = new Image();
186
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
imgSortDirection.ImageUrl = sortImgLoc;
187
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
dgItem.Cells[i].Controls.Add(imgSortDirection);
188
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
189
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
190
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
191
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
192
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
193
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
194
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
195
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Literal litSortSeq = new Literal();
196
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
litSortSeq.Text = sortOrderNo.ToString();
197
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
dgItem.Cells[i].Controls.Add(litSortSeq);
198
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
199
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
200
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
201
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
202
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
203
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
204
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
205
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
206
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
207
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030189/4fd96b3cf02f4c7b5c8964ac8167f7af.gif)
}
第二:详尽的分页信息显示,此功能没有封装成控件形式,直接在GridView_DataBound事件中对尾页操作即可。
下面是多列排序与分页显示代码的演示
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/34031c708bfe702fe82d01ff5c6593aa.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/0be121fa5b8988fbabbbc526af3b0fc0.gif)
<script runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
void PageDropDownList_SelectedIndexChanged(Object sender, EventArgs e)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
GridViewRow pagerRow = CustomersGridView.BottomPagerRow;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DropDownList pageList = (DropDownList)pagerRow.Cells[0].FindControl("PageDropDownList");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
CustomersGridView.PageIndex = pageList.SelectedIndex;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
void CustomersGridView_DataBound(Object sender, EventArgs e)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
GridViewRow pagerRow = CustomersGridView.BottomPagerRow;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnFirst = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnFirst");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnPrev = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnPrev");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnNext = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnNext");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnLast = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnLast");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (CustomersGridView.PageIndex == 0)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnFirst.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnPrev.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (CustomersGridView.PageIndex == CustomersGridView.PageCount-1)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnLast.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnNext.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (CustomersGridView.PageCount<=0)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnFirst.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnPrev.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnNext.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnLast.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DropDownList pageList = (DropDownList)pagerRow.Cells[0].FindControl("PageDropDownList");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Label pageLabel = (Label)pagerRow.Cells[0].FindControl("CurrentPageLabel");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (pageList != null)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < CustomersGridView.PageCount; i++)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int pageNumber = i + 1;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ListItem item = new ListItem(pageNumber.ToString() + "/" + CustomersGridView.PageCount.ToString(), pageNumber.ToString());
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (i == CustomersGridView.PageIndex)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
item.Selected = true;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
pageList.Items.Add(item);
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (pageLabel != null)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int currentPage = CustomersGridView.PageIndex + 1;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
pageLabel.Text = "当前页: " + currentPage.ToString() +
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
" / " + CustomersGridView.PageCount.ToString();
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030189/4fd96b3cf02f4c7b5c8964ac8167f7af.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</script>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<html>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<body>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<form id="Form1" runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<h3>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
GridView PagerTemplate Example</h3>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:WebGridView ID="CustomersGridView" DataSourceID="CustomersSqlDataSource" AutoGenerateColumns="true"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
AllowPaging="true" OnDataBound="CustomersGridView_DataBound" SortAscImageUrl="~/images/arrow-up.gif" SortDescImageUrl="~/images/arrow-down.gif" runat="server" AllowSorting="True" Width="723px">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<PagerStyle ForeColor="Blue" BackColor="LightBlue" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<PagerTemplate>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<table width="100%">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<tr>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<td width="70%">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:Label ID="MessageLabel" ForeColor="Blue" Text="页码:" runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:DropDownList ID="PageDropDownList" AutoPostBack="true" OnSelectedIndexChanged="PageDropDownList_SelectedIndexChanged"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="First" ID="linkBtnFirst" runat="server">首页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Prev" ID="linkBtnPrev" runat="server">上一页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Next" ID="linkBtnNext" runat="server">下一页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Last" ID="linkBtnLast" runat="server">末页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</td>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<td width="70%" align="right">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:Label ID="CurrentPageLabel" ForeColor="Blue" runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</td>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</tr>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</table>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</PagerTemplate>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</asp:WebGridView>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:SqlDataSource ID="CustomersSqlDataSource" SelectCommand="Select [CustomerID], [CompanyName], [Address], [City], [PostalCode], [Country] From [Customers]"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
ConnectionString="<%$ ConnectionStrings:NorthWindConnectionString%>" runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</asp:SqlDataSource>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</form>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</body>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</html>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
效果:
![](https://oscdn.geek-share.com/Uploads/Images/Content/200703/13/ffad363d3d9d458d3539f9236bf02c81.jpg)
如需要源码者:请加入WinFX团队。
posted on 2006-06-21 21:38 随风飘散 阅读(2665) 评论(7) 编辑 收藏 引用 网摘 所属分类: VS2005控件开发 、ASP.NET2.0
最近在使用ASP.net 2.0的GridView 控件时,发现排序与分页功能Microsoft实现的都很简单,比如排序,在点击列名的时候来触发整页的PostBack,然后排序,但是在列头上没有一个显示升序降序的图标,这会让最终用户使用时很迷惑,因为不知道是升序了还是降序了,所以今天首先解决的第一问题就是升序降序在列上显示图标,第二要解决的问题是默认GridView按列排序只能排一列的,也就是不能进行多列排序,而在实际应用中仅仅按照一列来排序是不能满足业务需求的,第三是GridView 分页问题,GridView预定义的分页页码显示,比较简单,而实际应用中,分页可能不是只显示首页,上一页,下一页,末页,或者是数字的页码那么简单,应该更需要,跳转,当前的页码,总页数等,更详尽的信息。
第一:GridView 多列排序与排序图标显示
首先我们可以新建一个类库程序,主要需要引用System.Web.Dll文件
然后新建一个类,这个类继承与GridView控件,我们只需要对部分方法进行重新即可。
我的演示的例子,采用了单列排序,如果启用多列排序,把控件的AllowMultiColumnSorting设置为True就是
多列排序。
1
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
public class WebGridView:GridView
2
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/34031c708bfe702fe82d01ff5c6593aa.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/0be121fa5b8988fbabbbc526af3b0fc0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
3
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
属性#region 属性
4
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
5
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 是否启用或者禁止多列排序
6
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
7
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
8
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("是否启用多列排序功能"),
9
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
10
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue("false"),
11
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
12
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public bool AllowMultiColumnSorting
13
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
14
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
15
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
16
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["EnableMultiColumnSorting"];
17
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? (bool)o : false);
18
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
19
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
20
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
21
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
AllowSorting = true;
22
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["EnableMultiColumnSorting"] = value;
23
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
24
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
25
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
26
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 升序时显示图标
27
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
28
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
29
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("升序时显示图标"),
30
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
31
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Editor("System.Web.UI.Design.UrlEditor", typeof(System.Drawing.Design.UITypeEditor)),
32
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue(""),
33
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
34
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
35
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public string SortAscImageUrl
36
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
37
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
38
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
39
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["SortImageAsc"];
40
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? o.ToString() : "");
41
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
42
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
43
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
44
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["SortImageAsc"] = value;
45
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
46
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
47
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
48
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 降序时显示图标
49
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
50
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
[
51
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Description("降序时显示图标"),
52
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Category("排序"),
53
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Editor("System.Web.UI.Design.UrlEditor", typeof(System.Drawing.Design.UITypeEditor)),
54
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DefaultValue(""),
55
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
]
56
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
public string SortDescImageUrl
57
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
58
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
get
59
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
60
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
object o = ViewState["SortImageDesc"];
61
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return (o != null ? o.ToString() : "");
62
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
63
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
set
64
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
65
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ViewState["SortImageDesc"] = value;
66
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
67
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
68
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
69
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
重写方法#region 重写方法
70
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected override void OnSorting(GridViewSortEventArgs e)
71
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
72
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
73
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
74
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
e.SortExpression = GetSortExpression(e);
75
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
76
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
77
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
base.OnSorting(e);
78
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
79
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected override void OnRowCreated(GridViewRowEventArgs e)
80
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
81
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (e.Row.RowType == DataControlRowType.Header)
82
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
83
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (SortExpression != String.Empty)
84
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
85
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DisplaySortOrderImages(SortExpression, e.Row);
86
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
this.CreateRow(0, 0, DataControlRowType.EmptyDataRow, DataControlRowState.Normal);
87
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
88
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
89
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
base.OnRowCreated(e);
90
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
91
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
92
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
受保护的方法#region 受保护的方法
93
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
94
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 获取排序表达式
95
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
96
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected string GetSortExpression(GridViewSortEventArgs e)
97
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
98
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string[] sortColumns = null;
99
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortAttribute = SortExpression;
100
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
101
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortAttribute != String.Empty)
102
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
103
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortColumns = sortAttribute.Split(",".ToCharArray());
104
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
105
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortAttribute.IndexOf(e.SortExpression) > 0 || sortAttribute.StartsWith(e.SortExpression))
106
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
107
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortAttribute = ModifySortExpression(sortColumns, e.SortExpression);
108
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
109
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
110
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
111
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortAttribute += String.Concat(",", e.SortExpression, " ASC ");
112
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
113
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return sortAttribute.TrimStart(",".ToCharArray()).TrimEnd(",".ToCharArray());
114
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
115
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
116
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
117
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 修改排序顺序
118
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
119
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected string ModifySortExpression(string[] sortColumns, string sortExpression)
120
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
121
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string ascSortExpression = String.Concat(sortExpression, " ASC ");
122
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string descSortExpression = String.Concat(sortExpression, " DESC ");
123
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
124
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < sortColumns.Length; i++)
125
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
126
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
127
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (ascSortExpression.Equals(sortColumns[i]))
128
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
129
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortColumns[i] = descSortExpression;
130
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
131
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
132
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (descSortExpression.Equals(sortColumns[i]))
133
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
134
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Array.Clear(sortColumns, i, 1);
135
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
136
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
137
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
138
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
return String.Join(",", sortColumns).Replace(",,", ",").TrimStart(",".ToCharArray());
139
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
140
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
141
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
142
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 获取当前的表达式对所选列进行排序
143
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
144
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected void SearchSortExpression(string[] sortColumns, string sortColumn, out string sortOrder, out int sortOrderNo)
145
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
146
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = "";
147
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrderNo = -1;
148
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < sortColumns.Length; i++)
149
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
150
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortColumns[i].StartsWith(sortColumn))
151
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
152
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrderNo = i + 1;
153
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
154
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
155
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = sortColumns[i].Substring(sortColumn.Length).Trim();
156
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
157
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
158
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
159
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
sortOrder = ((SortDirection == SortDirection.Ascending) ? "ASC" : "DESC");
160
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
161
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
162
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
163
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
164
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
/**//// <summary>
165
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
/// 绘制升序降序的图片
166
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
/// </summary>
167
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
protected void DisplaySortOrderImages(string sortExpression, GridViewRow dgItem)
168
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
169
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string[] sortColumns = sortExpression.Split(",".ToCharArray());
170
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
171
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < dgItem.Cells.Count; i++)
172
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
173
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (dgItem.Cells[i].Controls.Count > 0 && dgItem.Cells[i].Controls[0] is LinkButton)
174
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
175
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortOrder;
176
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int sortOrderNo;
177
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string column = ((LinkButton)dgItem.Cells[i].Controls[0]).CommandArgument;
178
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
SearchSortExpression(sortColumns, column, out sortOrder, out sortOrderNo);
179
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortOrderNo > 0)
180
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
181
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
string sortImgLoc = (sortOrder.Equals("ASC") ? SortAscImageUrl : SortDescImageUrl);
182
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
183
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (sortImgLoc != String.Empty)
184
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
185
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Image imgSortDirection = new Image();
186
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
imgSortDirection.ImageUrl = sortImgLoc;
187
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
dgItem.Cells[i].Controls.Add(imgSortDirection);
188
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
189
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
190
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else
191
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
192
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
193
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (AllowMultiColumnSorting)
194
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
195
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Literal litSortSeq = new Literal();
196
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
litSortSeq.Text = sortOrderNo.ToString();
197
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
dgItem.Cells[i].Controls.Add(litSortSeq);
198
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
199
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
200
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
201
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
202
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
203
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
204
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
205
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
206
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
#endregion
207
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030189/4fd96b3cf02f4c7b5c8964ac8167f7af.gif)
}
第二:详尽的分页信息显示,此功能没有封装成控件形式,直接在GridView_DataBound事件中对尾页操作即可。
下面是多列排序与分页显示代码的演示
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/34031c708bfe702fe82d01ff5c6593aa.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/0be121fa5b8988fbabbbc526af3b0fc0.gif)
<script runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
void PageDropDownList_SelectedIndexChanged(Object sender, EventArgs e)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
GridViewRow pagerRow = CustomersGridView.BottomPagerRow;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DropDownList pageList = (DropDownList)pagerRow.Cells[0].FindControl("PageDropDownList");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
CustomersGridView.PageIndex = pageList.SelectedIndex;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
void CustomersGridView_DataBound(Object sender, EventArgs e)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
GridViewRow pagerRow = CustomersGridView.BottomPagerRow;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnFirst = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnFirst");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnPrev = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnPrev");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnNext = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnNext");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
LinkButton linkBtnLast = (LinkButton)pagerRow.Cells[0].FindControl("linkBtnLast");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (CustomersGridView.PageIndex == 0)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnFirst.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnPrev.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (CustomersGridView.PageIndex == CustomersGridView.PageCount-1)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnLast.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnNext.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
else if (CustomersGridView.PageCount<=0)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnFirst.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnPrev.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnNext.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
linkBtnLast.Enabled = false;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
DropDownList pageList = (DropDownList)pagerRow.Cells[0].FindControl("PageDropDownList");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
Label pageLabel = (Label)pagerRow.Cells[0].FindControl("CurrentPageLabel");
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (pageList != null)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
for (int i = 0; i < CustomersGridView.PageCount; i++)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int pageNumber = i + 1;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
ListItem item = new ListItem(pageNumber.ToString() + "/" + CustomersGridView.PageCount.ToString(), pageNumber.ToString());
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (i == CustomersGridView.PageIndex)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
item.Selected = true;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
pageList.Items.Add(item);
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
if (pageLabel != null)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/3112b7b6526db5bc83e275260ae60525.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030173/f2671b7f42ce505d9bf55a7a0ca257fb.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/b854634c0904529d4018c4c3336be836.gif)
{
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
int currentPage = CustomersGridView.PageIndex + 1;
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
pageLabel.Text = "当前页: " + currentPage.ToString() +
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030194/587e34b10dcf5efbc0859b53470a2db3.gif)
" / " + CustomersGridView.PageCount.ToString();
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030175/eec4c0236afc26744c9c4e910bc34958.gif)
}
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030189/4fd96b3cf02f4c7b5c8964ac8167f7af.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</script>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<html>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<body>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<form id="Form1" runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<h3>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
GridView PagerTemplate Example</h3>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:WebGridView ID="CustomersGridView" DataSourceID="CustomersSqlDataSource" AutoGenerateColumns="true"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
AllowPaging="true" OnDataBound="CustomersGridView_DataBound" SortAscImageUrl="~/images/arrow-up.gif" SortDescImageUrl="~/images/arrow-down.gif" runat="server" AllowSorting="True" Width="723px">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<PagerStyle ForeColor="Blue" BackColor="LightBlue" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<PagerTemplate>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<table width="100%">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<tr>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<td width="70%">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:Label ID="MessageLabel" ForeColor="Blue" Text="页码:" runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:DropDownList ID="PageDropDownList" AutoPostBack="true" OnSelectedIndexChanged="PageDropDownList_SelectedIndexChanged"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="First" ID="linkBtnFirst" runat="server">首页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Prev" ID="linkBtnPrev" runat="server">上一页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Next" ID="linkBtnNext" runat="server">下一页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:LinkButton CommandName="Page" CommandArgument="Last" ID="linkBtnLast" runat="server">末页</asp:LinkButton>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</td>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<td width="70%" align="right">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:Label ID="CurrentPageLabel" ForeColor="Blue" runat="server" />
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</td>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</tr>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</table>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</PagerTemplate>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</asp:WebGridView>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
<asp:SqlDataSource ID="CustomersSqlDataSource" SelectCommand="Select [CustomerID], [CompanyName], [Address], [City], [PostalCode], [Country] From [Customers]"
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
ConnectionString="<%$ ConnectionStrings:NorthWindConnectionString%>" runat="server">
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</asp:SqlDataSource>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</form>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</body>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
</html>
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
![](https://oscdn.geek-share.com/Uploads/Images/Content/2015/2015030171/f0cd6c7f9e7ae96feae062cb48f670f0.gif)
效果:
![](https://oscdn.geek-share.com/Uploads/Images/Content/200703/13/ffad363d3d9d458d3539f9236bf02c81.jpg)
如需要源码者:请加入WinFX团队。
posted on 2006-06-21 21:38 随风飘散 阅读(2665) 评论(7) 编辑 收藏 引用 网摘 所属分类: VS2005控件开发 、ASP.NET2.0
相关文章推荐
- ASP.Net2.0GridView多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页(转)
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页。
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页。(转帖)
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0 GridView 多列排序,显示排序图标,分页
- ASP.Net2.0GridView多列排序,显示排序图标,分页
- GridView 实现自定义分页、排序、查询、添加、编辑、多选删除、导出、突出显示等常见应用实现(cs)
- Gridview实现多列排序,并显示图标
- jquery+ashx无刷新GridView数据显示插件(实现分页、排序、过滤功能)
- GridView 实现自定义分页、排序、查询、添加、编辑、多选删除、导出、突出显示等常见应用实现
- GridView 实现自定义分页、排序、查询、添加、编辑、多选删除、导出、突出显示等常见应用实现
- ASP.NET-GridView分页排序显示
- [转]Gridview实现多列排序,并显示图标
- jquery+ashx无刷新GridView数据显示插件(实现分页、排序、过滤功能)