如何动态重新排序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或绑定之前的某个地方执行此操作。