using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Net;
using System.Text;
using System.Text.RegularExpressions;
using System.Web.UI.WebControls;
using dynamic = System.Linq.Dynamic;
using System.Linq.Expressions;
namespace Project.Lib.Extensions
{
public static partial class Utils
{
public static List<T> SortForMe<T>(this List<T> list, string propertyName,SortDirection sortDirection)
{
string exp1 = string.Format("model.{0}", propertyName);
var p1 = Expression.Parameter(typeof(T), "model");
var e1 = dynamic.DynamicExpression.ParseLambda(new[] { p1 }, null, exp1);
if (e1 != null)
{
if (sortDirection==SortDirection.Ascending)
{
var result = list.OrderBy((Func<T, object>)e1.Compile()).ToList();
return result;
}
else
{
var result = list.OrderByDescending((Func<T, object>)e1.Compile()).ToList();
return result;
}
}
return list;
}
}
}
我正在使用此代码按 propertyName 对我的通用列表进行排序。当属性类型为string
时,此代码成功运行,但当类型为long
orint
时,我收到此异常:
无法将“System.Func`2[Project.Lib.Model.UserQueryCount,System.Int64]”类型的对象转换为“System.Func`2[Project.Lib.Model.UserQueryCount,System.Object]”。
var result = list.OrderBy((Func<T, dyamic>)e1.Compile()).ToList();
在上面的行中,我决定使用dynamic
,但再次遇到异常。我应该怎么办?
我改变了我的方法是这样的:
public static List<TModel> SortForMe<TModel>(this List<TModel> list, string propertyName,SortDirection sortDirection) where TModel:class
{
var ins = Activator.CreateInstance<TModel>();
var prop= ins.GetType().GetProperty(propertyName);
var propertyType = prop.PropertyType;
string exp1 = string.Format("model.{0}", propertyName);
var p1 = System.Linq.Expressions.Expression.Parameter(typeof(TModel), "model");
var e1 = System.Linq.Dynamic.DynamicExpression.ParseLambda(new[] { p1 }, null, exp1);
if (e1 != null)
{
if (sortDirection==SortDirection.Ascending)
{
return list.OrderBy((Func<TModel, propertyType>)e1.Compile()).ToList();
}
return list.OrderByDescending((Func<TModel, propertyType>)e1.Compile()).ToList();
}
return list;
}
我使用反射获得了 propertyType,但在 Func 中我不能像这样使用它:"Func<TModel, propertyType>"
有什么方法可以解决这个问题
谢谢您的帮助。