我在 datagridview 中有一个单元格,在其中以自定义格式显示时间。我需要当使用进入编辑模式(例如通过双击)时,我需要将字符串值更改为表示时间(以分钟为单位)的整数。
当我尝试更改“CellEnter”事件中的单元格值时,它似乎没有响应。实际上,它似乎并没有在任何事件中改变单元格值。
请不要介意将时间转换为字符串的细节,反之亦然,我的问题是当用户双击单元格时如何成功更改单元格的内容。
编辑(代码+解决方案):我所做的是使用另一列来存储实际值(不带格式)。在该列的单元格格式设置中,我将值传递给自定义格式函数以填充我的列。
private void gridview_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e)
{
if (e.ColumnIndex == 3 && e.Value != null && e.Value.ToString() != "")
{
//fill the unbound textbox column (5) from raw value column (3)
string newValue = TimeAttendanceHelper.FormatHourlyDuration(e.Value);
gridview.Rows[e.RowIndex].Cells[5].Value = newValue;
}
}
然后感谢 TaW,在 CellBeginEdit 上我显示了编辑它的原始值:
private void gridview_CellBeginEdit(object sender, DataGridViewCellCancelEventArgs e)
{
if (e.ColumnIndex == 5)
{
//on editing, use the value from raw data column (3)
gridview.Rows[e.RowIndex].Cells[5].Value = gridview.Rows[e.RowIndex].Cells[3].Value;
}
}
最后,当 CellEndEdit 时,我重新格式化新值:
private void gridview_CellEndEdit(object sender, DataGridViewCellEventArgs e)
{
if (e.ColumnIndex == 4)
{
//update value both in columns 3 & 5
string newValue = tIME_SHIFTDataGridView.Rows[e.RowIndex].Cells[4].Value.ToString();
gridview.Rows[e.RowIndex].Cells[3].Value = newValue;
gridview.Rows[e.RowIndex].Cells[4].Value = TimeAttendanceHelper.FormatHourlyDuration(newValue);
}
}