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