【问题标题】:Sort GridView by column populated in RowDataBound event按 RowDataBound 事件中填充的列对 GridView 进行排序
【发布时间】:2011-11-21 13:28:23
【问题描述】:

我有一个填充了用户信息的 GridView。

System.Web.Security.MembershipUserCollection users = System.Web.Security.Membership.GetAllUsers();        
grid.DataSource = users;
this.DataBind();

在 RowDataBound 事件中,它会查找其他用户信息并使用此信息填充列。

由于 GetAllUsers() 函数的性质,网格按用户名排序。我希望它按全名排序,全名是在 RowDataBound 偶数代码中查找和填充的列之一。我怎样才能做到这一点?我在为 GridView 排序时看到的所有内容都让您在将数据源应用到网格之前对其进行排序,但在这种情况下,我还没有该数据。

【问题讨论】:

  • 当您到达 RowDataBound 时,为时已晚。您需要重新考虑如何获取用户信息。

标签: c# asp.net sorting gridview


【解决方案1】:

您可以在数据绑定之前对gridview的数据源进行排序:

System.Web.Security.MembershipUserCollection users = System.Web.Security.Membership.GetAllUsers();
grid.DataSource = users.OfType<MembershipUser>().OrderBy(GetUserFullName, StringComparer.OrdinalIgnoreCase);

private static string GetUserFullName(MembershipUser user)
{
    // return here user's full name
    return user.Email;
}

【讨论】:

  • 这可能是我最好的选择 b/c 在那个事件中还有其他事情发生,并且重写所有内容对于客户看似简单的请求将花费太多时间。
猜你喜欢
  • 2018-08-13
  • 2011-05-24
  • 2014-08-30
  • 2013-03-14
  • 1970-01-01
  • 1970-01-01
  • 2011-12-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多