关于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; } }