DataGridView 中的复选框不选中

Checkbox in DataGridView doesnt Check

我创建一个DataGridView如下

 private void IniciarGV()
    {
        using (var db = new Entities())
        {

            var ListaPantallas = (from a in db.PANTALLAS
                                  select a).ToList();


            if (ListaPantallas != null)
            {

                gvPermisos.DataSource = ListaPantallas;
                gvPermisos.Columns["idPantalla"].Visible = false;
                gvPermisos.Columns["nombrepantalla"].HeaderText = "Nombre";
                //gvPermisos.Columns.Add(new DataGridViewCheckBoxColumn());
                DataGridViewCheckBoxColumn checkBoxColumn = new DataGridViewCheckBoxColumn();
                checkBoxColumn.HeaderText = "Seleccione";
                checkBoxColumn.Width = 50;
                checkBoxColumn.Name = "checkBoxColumn";
                gvPermisos.Columns.Insert(0, checkBoxColumn);
                //gvPermisos.EndEdit();

            }

            db.Dispose();
        }
    }

之后,我使用相同的方法 linq

检索权限
var TraerPermisos = (from a in db.PERMISOS
                                 where a.IDUSUARIO == UsuarioEditar.idUsuario
                                 select a).ToList();

在我通过 gridview 将权限与我想检查的 ID 相匹配之后,用户可以编辑它们,但由于某种原因,它们总是显示为未标记

到目前为止这是我在每个论坛或 google 中遇到的,但它似乎不起作用

 foreach (PERMISOS item in TraerPermisos)
            {
                foreach (DataGridViewRow row in gvPermisos.Rows)
                {
                    var ValorPermisoEnGV = Convert.ToBoolean(row.Cells["checkBoxColumn"].Value);
                    var ValorPantalla = decimal.Parse(row.Cells["idPantalla"].Value.ToString());
                    if (ValorPantalla == item.IDPANTALLA)
                    {
                        row.Cells["checkBoxColumn"].Value = true;
                    }
                }
            }

这是我的表格的样子

我在启动时加载权限

 public ManejarUsuario()
    {
        InitializeComponent();
        IniciarComboBox();
        IniciarGV();
        if (UsuarioEditar.idUsuario != 0)
        {
            CargarDatos();
            btnCrearUsuario.Text = "Editar";
            CargarPrivilegios();
        }
    }

很抱歉 post,我尝试了很多选项,但 none 似乎可行

如果您只在驱动网格的数据中放入一个布尔值,生活就会轻松很多。首先,让我们为您的信息制作一个支架 class

class Perms{
  public int IdPantalla { get; set; }
  public string NombrePantalla { get; set; }
  public bool HasPermission { get; set; }
}

然后让查询生成一个列表:

//get all the IDPANTALLA this user has and put in a hash set
var TraerPermisos = (from a in db.PERMISOS
    where a.IDUSUARIO == UsuarioEditar.idUsuario
    select a.IDPANTALLA).ToHashSet();

//make a list of objects that includes a bool of whether the user has that permission 
//note you should have this be a class level variable for ease of use later/elsewhere 
ListaPantallas = (from a in db.PANTALLAS
    select new Perms { 
      IdPantalla a.IdPantalla, 
      HasPermission = TraerPermisos.Contains(a.idPantalla) , 
      NombrePantalla = a.nombrepantalla 
    }).ToList();

然后设置网格:

gvPermisos.DataSource = ListaPantallas;
gvPermisos.Columns["IdPantalla"].Visible = false;
gvPermisos.Columns[ "NombrePantalla"].HeaderText = "Nombre";
gvPermisos.Columns[ "HadPermission"].HeaderText = "Seleccione";

网格将在列表中找到 bool 属性 并将其作为检查列连接起来。它不需要你为它做一个专栏。您勾选的任何内容都会作为 true/false 存储在基础列表中,您可以例如 foreach(var x in ListaPantallas) if(x.HasPermission...

在绑定到数据源的 DGV 中操作数据时,操作数据源。还考虑让 Perms 实现 INotifyPropertyChanged(并考虑切换到使用绑定列表)