我有一个DataGridView,只读模式设置为true(不可编辑),它在表单加载时从数据库中获取值。当我将只读模式设置为false(可编辑模式)时,我希望特定列(例如Department)作为ComboBox可见,以便我可以从中选择值。当我进入只读模式时,ComboBox应该消失,DataGridView应该像正常情况下一样可见。如何实现呢? 我正在使用C#框架4.0,Winforms
我有一个DataGridView,只读模式设置为true(不可编辑),它在表单加载时从数据库中获取值。当我将只读模式设置为false(可编辑模式)时,我希望特定列(例如Department)作为ComboBox可见,以便我可以从中选择值。当我进入只读模式时,ComboBox应该消失,DataGridView应该像正常情况下一样可见。如何实现呢? 我正在使用C#框架4.0,Winforms
DataGridView
属性的只读状态更改DisplayStyle
。将DisplayStyle
设置为DataGridViewComboBoxDisplayStyle.Nothing
将隐藏下拉按钮。ReadOnly
属性,代码如下:private void mChangeReadOnlyButton_Click(object sender, EventArgs e)
{
ComboBoxColumn2.DisplayStyle = (dataGridView1.ReadOnly) ?
DataGridViewComboBoxDisplayStyle.ComboBox :
DataGridViewComboBoxDisplayStyle.Nothing;
dataGridView1.ReadOnly = !dataGridView1.ReadOnly;
}
可编辑:
只读:
我找到了解决问题的方法,想在这里发布一下。进入编辑模式后,运行以下代码可能会解决问题。
public void bgCombo(DataGridView dg)
{
foreach (DataGridViewRow row in dg.Rows)
{
DataGridViewComboBoxCell dgc = new DataGridViewComboBoxCell();
dgc.Value = row.Cells["Department"].Value;
row.Cells["Department"] = dgc;
}
}
在将dgc设置为dataGridCell之前,我们可以向其中添加项集合。希望它有所帮助。
问题:如果在编辑时列索引和行索引相同时,我会收到一个错误 - 操作无效,因为它会导致对SetCurrentCellAddressCore函数的重入调用。
For Each row As DataGridViewRow In dgv.Rows
Dim Cell As DataGridViewComboBoxCell = CType(row.Cells(4), DataGridViewComboBoxCell)
Cell.ReadOnly = True
Cell.DisplayStyle = DataGridViewComboBoxDisplayStyle.Nothing
If row.Cells(2).Value IsNot Nothing Then
Cell.ReadOnly = False
Cell.DisplayStyle = DataGridViewComboBoxDisplayStyle.ComboBox
End If
Next