当前位置:  开发笔记 > 编程语言 > 正文

在asp.net中对gridview列进行排序c#

如何解决《在asp.net中对gridview列进行排序c#》经验,为你挑选了1个好方法。

任何人都可以告诉函数在c#asp.net中对gridview的列进行排序.

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

谢谢!



1> davidfowl..:

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

    保持排序状态为viewstate(SortDirection和SortExpression)

    您可以根据当前的排序状态生成正确的linq表达式.

手动处理网格中的Sorting事件并使用我编写的这个帮助器按SortExpression和SortDirection排序:

public static IQueryable SortBy(IQueryable 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)source.Provider.CreateQuery(methodCallExp);
}

db.Products.SortBy(e.SortExpression,e.SortDirection)

查看我的博客文章,了解如何执行此操作:

推荐阅读
保佑欣疼你的芯疼
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有