Using C# to recursively get a collection of contro

2019-01-20 15:07发布

Currently I am trying to extract a collection of dynamically created controls (checkboxes and dropdownlists) from a recursive control collection (repeater). This is the code I am using.

private void GetControlList<T>(ControlCollection controlCollection, ref List<T> resultCollection)
{
    foreach (Control control in controlCollection)
    {
        if (control.GetType() == typeof(T))
            resultCollection.Add((T)control);

        if (control.HasControls())
            GetControlList(controlCollection, ref resultCollection);
    }
}

I am having problems with the following line:

resultCollection.Add((T)control);

I get the error ...

Cannot convert type 'System.Web.UI.Control' to 'T'

Any ideas?

2条回答
看我几分像从前
2楼-- · 2019-01-20 15:45

Change it to

var c = control as T;
if (c != null)
    resultCollection.Add(c);

This will be faster than your cod, since it doesn't call GetType().
Note that it will also add controls that inherit T.

You'll also need to constrain the type parameter by adding where T : Control.

查看更多
SAY GOODBYE
3楼-- · 2019-01-20 15:54

Problem:

Since T can be a reference type or a value type, compiler needs more information.

You can not convert and Integer to Control.

Solution:

To fix this, add where T : Control or where T : class (a more general) constraint to state that T will always be a reference type.

Example:

private void GetControlList<T>(ControlCollection controlCollection, ref List<T> resultCollection)
where T : Control
{
    foreach (Control control in controlCollection)
    {
        //if (control.GetType() == typeof(T))
        if (control is T) // This is cleaner
            resultCollection.Add((T)control);

        if (control.HasControls())
            GetControlList(control.Controls, ref resultCollection);
    }
}
  • You also don't need ref keyword. Since, List is a reference type, it's reference will be passed.
查看更多
登录 后发表回答