asp.net GridView排序簡單實現(xiàn)
更新時間:2009年12月10日 22:33:17 作者:
使用javascript操作table排序才是實用的排序,這樣排序不怎么好,但是有時候可能會用來,記錄一下。
前臺:
代碼
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="GridViewSort.aspx.cs" Inherits="GridViewSort" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>GridView排序簡單實現(xiàn)</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="gdvSort" runat="server" OnSorting="gdvSort_Sorting">
</asp:GridView>
</div>
</form>
</body>
</html>
后臺:
代碼
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class GridViewSort : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState["SortOrder"] = "PID";
ViewState["OrderDire"] = "Desc";
Bind();
}
}
private void Bind()
{
gdvSort.AllowSorting = true;
DataView dv = getDt().DefaultView;
dv.Sort = (string)ViewState["SortOrder"] + " " + (string)ViewState["OrderDire"];
gdvSort.DataSource = dv;
gdvSort.DataBind();
}
/// <summary>
/// 連數(shù)據(jù)庫麻煩,直接構(gòu)造一個DataTable
/// </summary>
/// <returns></returns>
private DataTable getDt()
{
DataTable dt = new DataTable();
dt.Columns.Add("PID", typeof(System.Int32));
dt.Columns.Add("UserName", typeof(System.String));
for (int i = 0; i < 10; i++)
{
DataRow dr = dt.NewRow();
dr["PID"] = i;
dr["UserName"] = "姓名" + i;
dt.Rows.Add(dr);
}
return dt;
}
protected void gdvSort_Sorting(object sender, GridViewSortEventArgs e)
{
string sPage = e.SortExpression;
if (ViewState["SortOrder"].ToString() == sPage)
{
if (ViewState["OrderDire"].ToString() == "Desc")
{
ViewState["OrderDire"] = "Asc";
}
else
{
ViewState["OrderDire"] = "Desc";
}
}
else
ViewState["SortOrder"] = e.SortExpression;
Bind();
}
}
代碼
復(fù)制代碼 代碼如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="GridViewSort.aspx.cs" Inherits="GridViewSort" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
<title>GridView排序簡單實現(xiàn)</title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="gdvSort" runat="server" OnSorting="gdvSort_Sorting">
</asp:GridView>
</div>
</form>
</body>
</html>
后臺:
代碼
復(fù)制代碼 代碼如下:
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class GridViewSort : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState["SortOrder"] = "PID";
ViewState["OrderDire"] = "Desc";
Bind();
}
}
private void Bind()
{
gdvSort.AllowSorting = true;
DataView dv = getDt().DefaultView;
dv.Sort = (string)ViewState["SortOrder"] + " " + (string)ViewState["OrderDire"];
gdvSort.DataSource = dv;
gdvSort.DataBind();
}
/// <summary>
/// 連數(shù)據(jù)庫麻煩,直接構(gòu)造一個DataTable
/// </summary>
/// <returns></returns>
private DataTable getDt()
{
DataTable dt = new DataTable();
dt.Columns.Add("PID", typeof(System.Int32));
dt.Columns.Add("UserName", typeof(System.String));
for (int i = 0; i < 10; i++)
{
DataRow dr = dt.NewRow();
dr["PID"] = i;
dr["UserName"] = "姓名" + i;
dt.Rows.Add(dr);
}
return dt;
}
protected void gdvSort_Sorting(object sender, GridViewSortEventArgs e)
{
string sPage = e.SortExpression;
if (ViewState["SortOrder"].ToString() == sPage)
{
if (ViewState["OrderDire"].ToString() == "Desc")
{
ViewState["OrderDire"] = "Asc";
}
else
{
ViewState["OrderDire"] = "Desc";
}
}
else
ViewState["SortOrder"] = e.SortExpression;
Bind();
}
}
相關(guān)文章
深入淺析WinForm 進(jìn)程、線程及區(qū)別介紹
進(jìn)程是一個具有獨(dú)立功能的程序關(guān)于某個數(shù)據(jù)集合的一次運(yùn)行活動。線程,有時被稱為輕量級進(jìn)程(Lightweight Process,LWP),是程序執(zhí)行流的最小單元。這篇文章主要介紹了WinForm 進(jìn)程、線程的相關(guān)資料,需要的朋友可以參考下2016-09-09.NET使用YARP通過編碼方式配置域名轉(zhuǎn)發(fā)實現(xiàn)反向代理
這篇文章介紹了.NET使用YARP通過編碼方式配置域名轉(zhuǎn)發(fā)實現(xiàn)反向代理的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09Asp.net開發(fā)之webform圖片水印和圖片驗證碼的實現(xiàn)方法
這篇文章主要介紹了Asp.net開發(fā)之webform圖片水印和圖片驗證碼的實現(xiàn)方法,實現(xiàn)思路分為前后臺代碼和效果展示,非常不錯具有參考借鑒價值,需要的朋友可以參考下2016-10-10asp.net 保存、修改沒有 runat=server控件的控件值的一個解決方案
asp.net 保存、修改沒有 runat=server控件的控件值的一個解決方案,需要的朋友可以參考下。2011-10-10asp.net用url重寫URLReWriter實現(xiàn)任意二級域名 高級篇
Asp.net 用url重寫(URLReWriter)實現(xiàn)任意二級域名,需要的朋友可以參考下,建議先看一下上一篇文章。2009-11-11VS2015+Qt5+OpenCV3開發(fā)環(huán)境配置
這篇文章主要為大家詳細(xì)介紹了VS2015+Qt5+OpenCV3開發(fā)環(huán)境配置,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-06-06asp.net實現(xiàn)在非MVC中使用Razor模板引擎的方法
這篇文章主要介紹了asp.net實現(xiàn)在非MVC中使用Razor模板引擎的方法,較為詳細(xì)的分析了Razor模板引擎的使用技巧,需要的朋友可以參考下2015-06-06Asp.Net MVC 分頁、檢索、排序整體實現(xiàn)代碼
很多時候需要這樣的功能,對表格進(jìn)行分頁、排序和檢索。本篇文章主要介紹了Asp.Net MVC 分頁、檢索、排序整體實現(xiàn),有興趣的可以了解一下。2017-01-01