我有允许编辑的DataGridView(ReadOnly = false)。 DataGridView还可能有一个或多个与其数据源关联的过滤器。例如:
(myDataGridView.DataSource as DataTable).DefaultView.RowFilter = "[myColumn] = 'value'";
如果应用了过滤器,并且用户在myColumn中编辑了该字段,则该行会立即“消失”,因为它不再符合过滤器的条件。有没有办法抑制或取消此操作?理想情况下,我希望用户“刷新”网格,以便随意重新应用过滤器。
答案 0 :(得分:0)
您只需在某个RowFilter
方法中设置Refresh
,然后只调用该方法。但是,您必须在某个适当的事件处理程序(例如or
事件处理程序)中向RowFilter
添加一些CellEndEdit
条件,以防止当前行无论用户输入什么值都会消失:
string baseFilter = "[myColumn] = 'value'";
//CellEndEdit event handler for your myDataGridView
private void myDataGridView_CellEndEdit(object sender, DataGridViewCellEventArgs e){
(myDataGridView.DataSource as DataTable).DefaultView.RowFilter = baseFilter + " OR [myColumn] = '" + myDataGridView[e.ColumnIndex,e.RowIndex].Value + "'";
}
//you can call this method such as in some Click event handler of some Refresh Button
public void RefreshGrid(){
(myDataGridView.DataSource as DataTable).DefaultView.RowFilter = baseFilter;
}
答案 1 :(得分:0)
'King King'所说的方法不太好,因为它会导致显示该列具有相似值的所有其他行。
您可以选择避免使用DataTable.DefaultView.RowFilter
的自动过滤机制,而是在DataGridView的所有行中执行循环,并检查过滤标准以设置每行Visible
属性。
void applyFilter()
{
foreach (DataGridViewRow row in grid1.Rows)
{
string columnA = row.Cells["ColumnA"].Value as string;
string columnB = row.Cells["ColumnB"].Value as string;
row.Visible = (columnA == "valueA" && columnB == "valueB");
}
}
您也可以使用类似:columnA.IndexOf("valueA", StringComparison.OrdinalIgnoreCase) > -1
的内容来搜索'包含'条件(例如RowFilter = '%valueA%'
)。