我有一个包含搜索参数的类(SearchParameters),然后使用名为Querybuilder的泛型类创建基于这些的linq查询。这将返回结果,所有工作都完美无缺。
结果显示在GridView中,我目前正在为gridivew实现自定义排序,我将要搜索的字段添加到SearchParameters对象(使用流畅的界面)
SearchParameters=SearchParameters.SortResultsBy(e.SortExpression,e.NewSortOrder.ToString());
我需要将列的数据类型用作AddOrderByClause()方法的通用参数:
public void AddOrderByClause<D>(string field, Type sourceDateType)
{
var orderExpression = Expression.Lambda<Func<T, D>>(Expression.Property(resultExpression, field), resultExpression);
rootExpression = Expression.Call(
typeof(Queryable),
"OrderBy",
new Type[] { typeof(T), typeof(D) },
rootExpression,
orderExpression);
}
我可以很容易地找到列的数据类型,但是如何将其传递给AddOrderByClause()
(通用参数D)?
答案 0 :(得分:1)
public void AddOrderByClause<D,E>(string field, E sourceDataType)
{
.....
}
答案 1 :(得分:0)
使用反射来获取方法 AddOrderByClause ,然后使用 MakeGenericMethod 来获取泛型。这是一般性的想法(有点模糊,因为我不知道所有类型的名称是什么)。
Type MyTypeParameter; // TODO set this to type parameter D
Type type; // TODO set this to the type that contains the method "AddOrderByClause"
MethodInfo method = type.GetMethod("AddOrderByClause");
MethodInfo genericMethod = method.MakeGenericMethod(typeof(MyTypeParameter));
genericMethod.Invoke(MyClassInstance, FieldParam, SourceDataParam);
答案 2 :(得分:0)
但是如何将它传递给AddOrderByClause()(通用参数D)?
好像你已经有了这些列的数据类型,并且你想出了如何将它传递给Generic方法
以下是示例
首先修改AddOrderByClause以接受T(稍后在函数中使用)
public void AddOrderByClause<D,T>(String field)
{
....
}
然后调用AddOrderByClause,如
var data = SearchParameter;// Use actual data if SearchParameter is not correct
AddOrderByClause<D,date.GetType()>(fieldData);// assuming fieldData is something different
var data = SearchParameter;// Use actual data if SearchParameter is not currect