C# Datagridview checkbox

来源:互联网 发布:淘宝上的1号胶囊是什么 编辑:程序博客网 时间:2024/06/03 06:36

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


        }


原创粉丝点击