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

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

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

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

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

一些注意事项: – 当然我将AutogenerateColumns设置为false。 – 更改sql select列顺序因前一项而无效。 – 我不希望通过代码生成列。

有任何想法吗?

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

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

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

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

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

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