可能存在类似的问题,但它们似乎都没有帮助。所以我会尝试解释一个更具体的案例,看看是否有人可以帮助我:)。
这是事情,我有一个带有templatefields的gridview,我想让用户指定这些列的显示顺序。因此,用户创建一个视图并决定要显示哪个列的第一个,第二个,等等。
基本上,我需要在网格加载数据后更改列的顺序。
听起来很简单吧?嗯,显然不是。至少我还没有达到目的。
一些说明: - 当然我将AutogenerateColumns设置为false。 - 更改sql select列顺序因前一项而无效。 - 我不想通过代码生成列。
有什么想法吗?
答案 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