I\'m not really familiar with creating generic methods, so I thought I\'d put this question to the community & see what comes back. It might not even be a valid use of gener
I'm thinking generics is not exactly what you are looking for here.
Instead you might want to take one of two different approaches
Make all of your classes descend from a common one which has a virtual method called "Render" or something similiar. That way you can just call the classes render method.
Make all of your classes implement an Interface which has a Render method..
That you you would just call:
Although each class then has to implement it's own Render method, you would 1. avoid reflection, 2. have complete control on a class basis on what the output is.
For what you're trying to do, I think the main benefit of using generics would be to take advantage of type inference. If you declare your method as follows :
public static string GetTag<T>(this HtmlHelper h, T myObj, TagBuilder tag)
You won't have to specify the type parameter when calling it, because it will be inferred from the usage (i.e. the compiler will see that the second parameter's type is MyType
, so it will guess that T == MyType).
But anyway, you don't really need to specify the type : the method could call GetType
on the object, and use the resulting type the same way it would have used typeof(T)
, so generics aren't so useful here.
However, I see one reason to use them anyway : if you have an object of type MySubType
, which inherits from MyType
, you might want to render only properties defined in MyType
: in that case you just have to specify MyType
as the type parameter, overriding the type inference.
Here's a possible implementation :
public static string GetTag<T>(this HtmlHelper h, T myObj, TagBuilder tag)
{
Type t = typeof(T);
tag.Attributes.Add("class", t.Name);
foreach (PropertyInfo prop in t.GetProperties())
{
object propValue = prop.GetValue(myObj, null);
string stringValue = propValue != null ? propValue.ToString() : String.Empty;
tag.Attributes.Add(prop.Name, stringValue);
}
return tag.ToString();
}