如何动态重新排序gridview中的列

时间:2012-01-23 17:46:54

标签: c# asp.net .net gridview

可能存在类似的问题,但它们似乎都没有帮助。所以我会尝试解释一个更具体的案例,看看是否有人可以帮助我:)。

这是事情,我有一个带有templatefields的gridview,我想让用户指定这些列的显示顺序。因此,用户创建一个视图并决定要显示哪个列的第一个,第二个,等等。

基本上,我需要在网格加载数据后更改列的顺序。

听起来很简单吧?嗯,显然不是。至少我还没有达到目的。

一些说明: - 当然我将AutogenerateColumns设置为false。 - 更改sql select列顺序因前一项而无效。 - 我不想通过代码生成列。

有什么想法吗?

2 个答案:

答案 0 :(得分:18)

您可以在代码隐藏中修改Gridview的Columns集合。因此,执行此操作的一种方法是从集合中的当前位置移除列,然后将其重新插入新位置。

例如,如果您想将第二列移动到您可以执行的第一列:

var columnToMove = myGridView.Columns[1];
myGridView.Columns.RemoveAt(1);
myGridView.Columns.Insert(0, columnToMove);

如果你需要随机移动它们,那么你可能想要尝试克隆字段集合,清除GridView中的集合,然后按照你希望它们的顺序重新插入它们。< / p>

var columns = myGridView.Columns.CloneFields();
myGridView.Columns.Clear();
myGridView.Columns.Add(columns[2]);
myGridView.Columns.Add(columns[0]);
etc..

我不能100%确定这一切是否会在绑定到数据之后起作用,所以除非有理由不这样做,否则我会在Page_Init之前或绑定之前的某个地方进行。

答案 1 :(得分:0)

我知道这是一个非常老的问题,但是建议的答案并不能完全解决问题。

删除/添加动态列后,GridView的ViewState将失败。

如果您需要绑定任何事件(例如OnRowCommand和OnRowUpdating),则不会触发此类事件。

编辑:

如果需要答案,请查看此功能。

Protected Overrides Function CreateColumns(dataSource As PagedDataSource, useDataSource As Boolean) As ICollection