加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

在asp.net中排序gridview的列c#

发布时间:2020-12-16 00:05:30 所属栏目:asp.Net 来源:网络整理
导读:任何人都可以告诉函数在c#asp.net中对gridview的列进行排序. gridview的数据绑定来自使用linq创建的datacontext.我想单击列的标题来对数据进行排序. 谢谢! 解决方法 要做到这一点,您需要做两件事. 保持排序状态为viewstate(SortDirection和SortExpression)
任何人都可以告诉函数在c#asp.net中对gridview的列进行排序.

gridview的数据绑定来自使用linq创建的datacontext.我想单击列的标题来对数据进行排序.

谢谢!

解决方法

要做到这一点,您需要做两件事.

>保持排序状态为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 如何执行此操作:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读