在DataGridView编辑上禁止或取消过滤

时间:2013-09-30 20:05:57

标签: c# .net winforms datagridview

我有允许编辑的DataGridView(ReadOnly = false)。 DataGridView还可能有一个或多个与其数据源关联的过滤器。例如:

(myDataGridView.DataSource as DataTable).DefaultView.RowFilter = "[myColumn] = 'value'";

如果应用了过滤器,并且用户在myColumn中编辑了该字段,则该行会立即“消失”,因为它不再符合过滤器的条件。有没有办法抑制或取消此操作?理想情况下,我希望用户“刷新”网格,以便随意重新应用过滤器。

2 个答案:

答案 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%')。