C# Datagridview checkbox

关于checkbox列 (System.Windows.Forms.DataGridViewCheckBoxColumn),用法通常是:

a. 按照数据源,显示“选择”或“不选” (即打勾或不打勾);

b.  改变选中状态:选中<-->不选;

c. .获取选中的数据行;


有两种思路实现:

前提:  !!!传递给Datagridview 数据源类型是 DataTable (List不行)


1. 可视化编辑: 编辑如下图: 设置FalseVlaue和TrueValue:


a的实现,是通过设置item_check字段和数据源列名称一致,然后数据源数值分别设置为字符串类型值"true","false"即可。

b的实现, 要允许该列能编辑, 以及datagridview控件不是readonly;

c的实现, 遍历数据源的行,判断相应item_check列的值是否为true,然后复制到一个新的临时表;


2.   通过事件CellContentClick ,这种方法有个不好就是,数据源与视图的状态不关联。当然,可以按照上述那样设置FalseValue 和 TrueValue使他们关联。但是就不是最简单方法了。

实现过程如下: 

 a的实现还是类似上面;

 b的实现如下:

   private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
        {
            if (e.ColumnIndex == 0 && e.RowIndex != -1)
            {


                //获取控件的值
                DataGridViewCheckBoxCell cell = (DataGridViewCheckBoxCell)this.dataGridView1.Rows[e.RowIndex].Cells[0];
                Boolean flag = Convert.ToBoolean(cell.Value);
                //改变checkbox的状态值
              //  cell.Value = (!flag).ToString(); 


                //或者可以做其他事件处理程序
            }


        }

 c的实现通过读取实时的datagridview 行控件状态:

 private DataTable GetSelectRows()         {             DataTable ret = this.data.Clone();             int count = 0;             int length = dataGridView1.Rows.Count;             for (int i = 0; i < length; i++)             {                 if (this.dataGridView1.Rows[i].Cells[0].EditedFormattedValue.ToString() == "True") //checkbox的是否勾选                 {                     count++;                     DataRow row = data.Rows[i];                     ret.ImportRow(row);                 }                              }             if (count == 0)             {                 MessageBox.Show("请至少选择一条数据", "提示");                 return null;             }             else             {                 return ret;             }          }