C#2005 如何dataGridView的单元格的值发生了改变

第一步:在DataGridView控件的majorDataGrid_EditingControlShowing事件中给单元格绑定Enter和Leave 事件

private void majorDataGrid_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)

        {
            if (e.Control.GetType().Equals(typeof(DataGridViewTextBoxEditingControl)))//cell为类TextBox时
            {
                e.CellStyle.BackColor = Color.FromName("window");
                DataGridViewTextBoxEditingControl editingControl = e.Control as DataGridViewTextBoxEditingControl;
                editingControl.Leave += new EventHandler(editingControl_TextChanged);
                editingControl.Enter += new EventHandler(editingControl_Enter); 
            }
        }


第二步:当textConrol获取焦点的时候记录单元格的值

        private void editingControl_Enter(object sender, EventArgs e)
        {
            TextBox t = (TextBox)sender;
            preTextContent = t.Text;
        }


第三步:当光标离开单元格的时候比较进入和离开时单元格的值有没有发生变化,如果值发生变化说明发生了修改,此时利用该行的Tag属性来标注单元格已被修改

        private void editingControl_TextChanged(object sender, EventArgs e)
        {
            TextBox t = (TextBox)sender;
            editTextContent = t.Text;
            if (editTextContent != preTextContent)
            {
                majorDataGrid.Rows[majorDataGrid.CurrentCell.RowIndex].Tag = Constant.UPDATED;
            }

        }


如果有更好的方法请高人们指点,谢谢!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现DataGridView中合并单元格,并设置单元格的功能,可以使用DataGridView的CellPainting事件来自定义单元格的绘制,并在需要合并的单元格中设置合并后的。 以下是一个示例,演示如何将DataGridView中相邻的相同单元格合并为一个单元格,并在合并后的单元格中设置合并后的: ```csharp private void dataGridView1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e) { // 只对非表头单元格进行处理 if (e.RowIndex >= 0 && e.ColumnIndex >= 0 && e.RowIndex < dataGridView1.RowCount - 1) { DataGridViewCell curCell = dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex]; DataGridViewCell nextCell = dataGridView1.Rows[e.RowIndex + 1].Cells[e.ColumnIndex]; // 判断当前单元格和下一个单元格是否相同 if (curCell.Value != null && nextCell.Value != null && curCell.Value.Equals(nextCell.Value)) { // 下一个单元格被合并到当前单元格 e.AdvancedBorderStyle.Bottom = DataGridViewAdvancedCellBorderStyle.None; nextCell.Visible = false; // 设置合并后的单元格 DataGridViewCell mergeCell = curCell; mergeCell.Value = curCell.Value.ToString() + ", " + nextCell.Value.ToString(); } else { // 重新绘制当前单元格的下边框 e.AdvancedBorderStyle.Bottom = dataGridView1.AdvancedCellBorderStyle.Bottom; } } } ``` 在这个示例中,我们通过比较相邻单元格来判断是否需要进行合并。如果需要合并,我们将下一个单元格的可见性设置为false,并将当前单元格的下边框样式设置为None。然后,我们获取要合并的单元格curCell,将合并后的设置为curCell的和nextCell的拼接而成。最后,我们将mergeCell的设置为拼接后的。 需要注意的是,如果合并的单元格中存在单元格不同的情况,可能会出现不符合预期的情况。因此,在实现单元格合并功能时,需要根据实际情况进行适当的处理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值