【WinForm+DevExpress】GridView根据情况对某些单元格禁止修改

效果图

UesrId这一列的第三行和第四行无法进行编辑

实现

第一步:添加一个GridControl,并且将其设置为"在父容器中停靠",设置数据源

第二步:设置GridView的ShowingEditor事件

第三步:后台代码

  private bool DisabledConditional(GridView view, int row) {
            //获取userId列
            GridColumn col = view.Columns["userId"];
            //选中单元格的数据
            string val = Convert.ToString(view.GetRowCellValue(row, col));
            //是否等于1或者2
            return (val == "1" || val == "2");

        }


        private void gridView1_ShowingEditor(object sender, CancelEventArgs e)
        {
            GridView view = sender as GridView;
            //如果列名是"userId"且值不等于1或者2,则不可以编辑
            if (view.FocusedColumn.FieldName == "userId" && !DisabledConditional(view, view.FocusedRowHandle))
            {
                e.Cancel = true;
            }
        }

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现Devexpress WinForm GridControl单元格的可编辑状态更改,可以通过以下步骤完成: 1.打开GridControl的设计器,选择要更改的,找到其Editable选项,将其设置为True。 2.在代码中,可以使用GridView的ShowingEditor事件来控制该单元格是否可编辑。可以在该事件中添加条件判断,根据条件设置该单元格是否可编辑。 例如,以下代码实现了当名为“Name”的单元格中的值为“John”时,该单元格不可编辑: ``` private void gridView1_ShowingEditor(object sender, CancelEventArgs e) { GridView view = sender as GridView; if (view.FocusedColumn.FieldName == "Name") { string name = view.GetRowCellValue(view.FocusedRowHandle, view.Columns["Name"]).ToString(); if (name == "John") { e.Cancel = true; } } } ``` 3.如果需要动态更改某个单元格的可编辑状态,可以使用GridView的SetColumnEdit方法来设置该单元格的编辑器,从而实现单元格的可编辑状态更改。 例如,以下代码实现了当名为“Age”的单元格中的值大于等于18时,该单元格可编辑;否则该单元格不可编辑: ``` private void gridView1_CustomRowCellEdit(object sender, CustomRowCellEditEventArgs e) { GridView view = sender as GridView; if (e.Column.FieldName == "Age") { int age = Convert.ToInt32(view.GetRowCellValue(e.RowHandle, view.Columns["Age"])); if (age >= 18) { e.RepositoryItem = repositoryItemTextEdit1; //设置该单元格的编辑器为TextEdit } else { e.RepositoryItem = null; //设置该单元格的编辑器为空,从而禁止编辑 } } } ``` 通过以上步骤,可以实现Devexpress WinForm GridControl单元格的可编辑状态更改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值