[英]Abort sorting in DataGridView when row has been edited
我有2列的DataGridView。 first的SortMode設置為Automatic。
在此網格中有很多行,當我更改行中的值時(例如,從xyz更改為abc),我仍然處在該行所在的位置。 編輯的行跳到頂部。
我想中止這種自動排序,我想通過在列上單擊鼠標左鍵來進行電話排序。 是
我找到了一些解決方案(下面的代碼+我將SortMode設置為Programmatically),但我的行仍在跳:/有沒有人解決此問題的解決方案?
private void dataGridView1_ColumnHeaderMouseClick(object sender, DataGridViewCellMouseEventArgs e)
{
if (e.Button == MouseButtons.Left)
{
DataGridViewColumn newColumn =
dataGridView1.Columns[e.ColumnIndex];
SortOrder direction;
if (dataGridView1.SortOrder == SortOrder.Ascending)
{
dataGridView1.Sort(newColumn,
ListSortDirection.Ascending);
direction = SortOrder.Ascending;
}
else
{
dataGridView1.Sort(newColumn,
ListSortDirection.Descending);
direction = SortOrder.Descending;
}
newColumn.HeaderCell.SortGlyphDirection = direction;
}
}
為什么在捕獲DataGridView的Edit Event時不只是禁用排序?
private void dataGridView1_CellBeginEdit(object sender,
DataGridViewCellCancelEventArgs e)
{
foreach (DataGridViewColumn column in dataGridView1.Columns)
column.SortMode = DataGridViewColumnSortMode.NotSortable;
}
然后,您可以通過恢復此行為來恢復排序(通過在列的RightClick事件或任何上下文菜單項或其他事件中再次恢復它)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.