DataGridViewComboBoxColumn 值更改不会将 RowState 更改为已修改
Posted
技术标签:
【中文标题】DataGridViewComboBoxColumn 值更改不会将 RowState 更改为已修改【英文标题】:DataGridViewComboBoxColumn value change not changing RowState to modified 【发布时间】:2012-10-29 10:01:08 【问题描述】:我在我的数据网格视图中添加了一个查找组合框。对现有行的任何更改或添加新行都会将保存时 RowState 中的值更改为已修改或已添加。除了更改组合框中的值。保存时,RowState 保持不变。
我用来添加组合框的代码是。
DataGridViewComboBoxColumn cbQualification = new DataGridViewComboBoxColumn();
cbQualification.HeaderText = "Course Code";
DataSet myDataSet = GetData.GetCoursesData();
cbQualification.DataSource = myDataSet.Tables[0];
cbQualification.DisplayMember = "Code";
cbQualification.ValueMember = "ID";
cbQualification.DataPropertyName = "QualID";
grdPersonQuals.Columns.Insert (1,cbQualification);
保存事件使用代码。
grdPersonQuals.BindingContext[grdPersonQuals.DataSource, grdPersonQuals.DataMember].EndCurrentEdit();
foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
object x = row.RowState;
【问题讨论】:
【参考方案1】:我猜点击保存按钮时焦点仍然在您的组合框列中?我一直调用 DataGridView 的 EndEdit 方法来触发更新数据源。
所以在你的保存按钮事件中
grdPersonQuals.EndEdit();
您在绑定上下文中调用它,但我相信您需要在网格本身上调用它,以便将网格中的更改推送到它的数据源。
【讨论】:
【参考方案2】:如果未修改,您可以设置行状态
foreach (DataRow row in dsPersonQuals.Tables[0].Rows)
row.SetAdded(); // or row.SetModified();
object x = row.RowState;
【讨论】:
我不想设置它,我想在保存之前查看值行是否发生了变化。以上是关于DataGridViewComboBoxColumn 值更改不会将 RowState 更改为已修改的主要内容,如果未能解决你的问题,请参考以下文章