使用类扩展的GridView的控制 [英] use class extending gridview as control
问题描述
我做了一个扩展的类GridView控件添加生成列,使用时的AutoGenerateColumns = TRUE
,到列集合。
I made a class extending gridview to add columns generated, when using autogeneratecolumns=true
, to the columns collection.
using System;
using System.Data;
using System.Collections;
using System.Web.UI.WebControls;
public class GridViewEx1 : GridView
{
private DataControlFieldCollection originalColumns;
public GridViewEx1()
: base()
{
}
public void RecordColumns()
{
originalColumns = new DataControlFieldCollection();
foreach (DataControlField column in Columns)
originalColumns.Add(column as DataControlField);
}
public void ResetColumns()
{
if (originalColumns == null)
RecordColumns();
else
{
Columns.Clear();
foreach (DataControlField column in originalColumns)
Columns.Add(column as DataControlField);
}
}
protected override ICollection CreateColumns(PagedDataSource dataSource, bool useDataSource)
{
ResetColumns();
ICollection generatedColumns = base.CreateColumns(dataSource, useDataSource);
foreach (DataControlField column in generatedColumns)
if (!originalColumns.Contains(column))
Columns.Add(column as DataControlField);
return Columns;
}
}
但我无法弄清楚如何在asp.net页面中使用这个控制?
But I can't figure out how to use this control in the asp.net page?
我试图把我的原GridView和初始化它像这样
I tried taking my original gridview and initialising it like so
gv1 = new GridViewEx1(); // gv1 is the id of my gridview
但是,这只是我的呈现GridView的完全是空的。
But that just renders my gridview completely empty.
推荐答案
您需要注册页面上的控制。
You'll need to register your control on the page.
<%@ Register TagPrefix="CustomControls" Namespace="MyProject.MyControlNamespace" Assembly="MyProject" %>
<CustomControls:GridViewEx1 runat="server" />
在注册控件更多信息:<一href=\"http://weblogs.asp.net/scottgu/archive/2006/11/26/tip-trick-how-to-register-user-controls-and-custom-controls-in-web-config.aspx\" rel=\"nofollow\">http://weblogs.asp.net/scottgu/archive/2006/11/26/tip-trick-how-to-register-user-controls-and-custom-controls-in-web-config.aspx
这篇关于使用类扩展的GridView的控制的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!