如何在c#中编辑数据绑定组合框

时间:2014-11-10 14:59:41

标签: c# winforms datagridview combobox

在我的winForm应用程序中,我在datagridview中添加了数据绑定组合框列。用户需要能够从下拉列表中选择项目或写入组合框。但是当数据源设置时,它不会让我在组合框中写入。这是我的代码:

var entityModel= new AdminEntities();
var filterPractice = (from b in entityModel.FILTER where b.PRACTICE != null select b.PRACTICE).Distinct().OrderBy(y => y);
dgvCboColumn(filterPractice, "PRACTICE");
private void dgvCboColumn(dynamic item, string colName)
    {
        int i = dgvLoadTable.Columns[colName].Index;
        DataGridViewComboBoxColumn dgvCol = new DataGridViewComboBoxColumn();
        dgvCol.DataSource=item;
        dgvCol.DataPropertyName = colName;
        dgvLoadTable.Columns.Insert(i, dgvCol);
        dgvLoadTable.Columns[i].HeaderText = dgvLoadTable.Columns[i + 1].HeaderText;
        dgvLoadTable.Columns[i + 1].Visible = false;
        dgvLoadTable.Columns.RemoveAt(i + 1);
    }
  private void HandleEditShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
    {
        var cbo = e.Control as ComboBox;
        if (cbo == null)
        {
            return;
        }

        cbo.DropDownStyle = ComboBoxStyle.DropDown;
        cbo.Validating -= HandleComboBoxValidating;
        cbo.Validating += HandleComboBoxValidating;
    }
    private void HandleComboBoxValidating(object sender, CancelEventArgs e)
    {
        var combo = sender as DataGridViewComboBoxEditingControl;
        if (combo == null)
        {
            return;
        }
        if (!combo.Items.Contains(combo.Text)) 
        {
            var comboColumn = this.dgvLoadTable.Columns[this.dgvLoadTable.CurrentCell.ColumnIndex] as DataGridViewComboBoxColumn;
            combo.Items.Add(combo.Text);
            comboColumn.Items.Add(combo.Text);
            this.dgvLoadTable.CurrentCell.Value = combo.Text;
        }
    }

任何人都可以告诉我如何才能让这个组合框可以编辑?

1 个答案:

答案 0 :(得分:-1)

您可以使用Oledb或Ado记录集手动从数据源获取项目,并使用for循环手动填充comboBox ..所以基本上您也可以编辑项目..