当前位置:首页 > ASP.NET实例:手把手教你如何扩展GridView之自动排序篇

ASP.NET实例:手把手教你如何扩展GridView之自动排序篇

点击次数:1132  更新日期:2010-12-27
\n

看到这两天园子里面“强奸”GridView的兄弟们可真不少,自己也手痒,也凑凑热闹,写得好,大家鼓励鼓励,写的不好,大家多多指教。
首先说说本文要实现的目的,大家都知道GridView支持排序,但是每次排序的时候,都需要给GridView添加OnSorting事件,这么繁琐而费力,作为世界上最最聪明的程序员的我们难道没有抱怨么?废话少说,不才想到了一种解决这个问题的方法,可以让大家一劳永逸。下面就让兄弟我臭摆一下,希望园子里面的高高手,大大牛们给给面子,捧捧场,别取消兄弟。
首先创建一个GridViewEx的类,并继承GridView,然后添加如下委托


\n

public delegate void BindEventHandler();
在GridViewEx中添加如下代码:


\n

DataSet _ds;
[Description("自定义的DataSet类型数据源"),Category("扩展")]
public virtual DataSet DataSetSource
{
get
{
return _ds;
}
set
{
_ds = value;
}
}
我们在使用GridViewEx的时候,就只需要设定DataSetSource属性,这个将限定本扩展组件只支持DataSet类型的数据源,其他类型数据源有兴趣的,大家可以进行扩展,象ArrayList,List<>这些都是可以的。
接下来的工作是为GridViewEx添加OnBind事件,如下:


\n

public event BindEventHandler Bind;
public virtual void OnBind()
{
if (Bind != null)
{
Bind();
if (DataSetSource != null)
{
DataView dv = DataSetSource.Tables[0].DefaultView;
dv.Sort = SortExpressionStr;
this.DataSource = dv;


\n

this.DataBind(); }
}
}
有了这个事件,我们就可以让GridView去类外部获取数据源,然后回到类本身来组织数据和进行绑定了。
接下来,需要声明两个方法


\n

[Description("排序表达式"),Category("扩展")]
protected virtual string SortExpressionStr
{
get
{
if (ViewState["SortExpression"] == null)
{
return null;
}
return ViewState["SortExpression"].ToString();
}
set
{
ViewState["SortExpression"] = value;
}
}
[Description("排序方向"),Category("扩展")]
protected virtual string SortDirectionStr
{
get
{
if (ViewState["SortDirection"] == null)
{
return “DESC”;
}
if (ViewState["SortDirection"].ToString().ToLower() != “asc” && ViewState["SortDirection"].ToString().ToLower() != “desc”)
{
return “DESC”;
}
return ViewState["SortDirection"].ToString();
}
set
{
ViewState["SortDirection"] = value;
}
}
和下面的属性


\n


public string SortExpressionEx
{
get
{
if (ViewState["SortExpressionEx"] == null)
{
return null;
}
return ViewState["SortExpressionEx"].ToString();
}
set
{
ViewState["SortExpressionEx"] = value;
}
}
然后重写OnSorting事件如下:


\n

protected override void OnSorting(GridViewSortEventArgs e)
{
SortExpressionEx = e.SortExpression;
SortExpressionStr = e.SortExpression + ” ” + SortDirectionStr;
OnBind();
if (SortDirectionStr.ToLower() == “asc”)
{
SortDirectionStr = “DESC”;
}
else
{
SortDirectionStr = “ASC”;
}
}
并且增加如下的OnLoad事件


\n

protected override void OnLoad(EventArgs e)
{
if (!Page.IsPostBack)
{
try
{
OnBind();
}
catch
{


\n

}
}
base.OnLoad(e);
}


\n

经过上面这样简单的改造,您再次使用GridViewEx的时候,在前台页面使用的时候,您只要按照这样的格式就可以了:
<cc1:GridViewEx id=”gridViewEx1″ OnBind=”BindData” runat=”server” AllowSorting=”True”>
<Columns>
<asp:TemplateField HeaderText=”序号” SortExpression=”ID”><%#Eval(”ID”)%></asp:TemplateField>
</Columns>
</cc1:GridViewEx>
后台只需要添加这样的方法


\n

public void BindData()
{
DataSet ds = new DataSet();
ds = //获得DataSet;
gridView1.DataSetSource = ds;
}
在页面中的Page_Load方法中,也不用再写
if(!Page.IsPostBack)
{
BindData();//绑定GridView的方法
}
注意,如果需要重新绑定GridView,只需要这样GridViewEx1.OnBind();即可。

\n

来源:jillzhang的blogs

\n