解决方法
要做到这一点,您需要做两件事.
>保持排序状态为viewstate(SortDirection和SortExpression)
>您可以根据当前的排序状态生成正确的linq表达式.
手动处理网格中的Sorting事件并使用我编写的这个帮助器按SortExpression和SortDirection排序:
public static IQueryable<T> SortBy<T>(IQueryable<T> source,string sortExpression,SortDirection direction) { if (source == null) { throw new ArgumentNullException("source"); } string methodName = "OrderBy"; if (direction == SortDirection.Descending) { methodName += "Descending"; } var paramExp = Expression.Parameter(typeof(T),String.Empty); var propExp = Expression.PropertyOrField(paramExp,sortExpression); // p => p.sortExpression var sortLambda = Expression.Lambda(propExp,paramExp); var methodCallExp = Expression.Call( typeof(Queryable),methodName,new[] { typeof(T),propExp.Type },source.Expression,Expression.Quote(sortLambda) ); return (IQueryable<T>)source.Provider.createquery(methodCallExp); }
db.Products.sortBy(e.sortExpression,e.sortDirection)
查看my blog post 如何执行此操作:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。