Winform DataGridView数据绑定,数据读取

第一种:绑定datasource,BindingList<T>,List<T>

绑定datasource:
数据读取:修改datasource,直接修改绑定的datatable数据源,然后重新绑定到datagridview中。

绑定BindingList<T>:
datagridview1.dataSource = plat_OperateParamConfigDtoBindingList
= new BindingList<Plat_OperateParamConfigDto>(plat_OperateParamConfigDtoList);
数据读取: 直接操作plat_OperateParamConfigDtoBindingList对象就可以实现对datagridview1数据源进行增删改。

绑定List<T>:
数据读取:datagridview1.datasource as List<T>

我们在添加行时,更新datatable ,List<T>,BindingList<T>,建议使用BindingList<T>数据绑定。

第二种:动态添加行DataGridViewRow,列DataGridViewColumn

动态添加行

     //首先 声明一个 DataGridViewRow 对象 (即要添加的行)

     DataGridViewRow dr = new DataGridViewRow();   

    //设置要添加行的列

    DataGridViewCheckBoxCell check=new DataGridViewCheckBoxCell();
    DataGridViewTextBoxCell text=new DataGridViewTextBoxCell();
    dr.Cells.Add(check);
    dr.Cells.Add(text);

    //设置列的值
    dr.Cells[1].Value = "aaaa";

    //将声明的行添加到dataGridView1 中

    dataGridView1.Rows.Add(dr);

//添加列

   DataGridViewColumn dc = new DataGridViewColumn();
    
   dc.DataPropertyName = "FID";
    dc.Visible = false;
  dc.SortMode = DataGridViewColumnSortMode.NotSortable;
   dc.HeaderText = "唯一ID";
  dc.CellTemplate = null;
  this.dataGridView1.Columns.Add(dc);
 

数据读取:

	for (int i = 0; i < dataGridView1.Rows.Count; i++)
    {
        Console.WriteLine(dataGridView1.Rows[i].Cells[0].Value);
    }

特别提醒:控件被数据绑定时,无法以编程方式向 DataGridView 的行集合中添加行。
当使用datagridview绑定了数据库之后,就无法通过简单的datagridview.rows.add()来添加一行

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
dbfC#DataGridView中的常用技巧 只列出技巧部分,后面会有补充 0(最基本的技巧). 获取某列中的某行(某单元格)中的内容 this.currentposition = this.dataGridView1.BindingContext [this.dataGridView1.DataSource, this.dataGridView1.DataMember].Position; bookContent = this.database.dataSet.Tables[0].Rows [this.currentposition][21].ToString().Trim(); MessageBox.Show(bookContent); 1、自定义列 //定义列宽 this.dataGridView1.Columns[0].Width = 80; this.dataGridView1.Columns[1].Width = 80; this.dataGridView1.Columns[2].Width = 180; this.dataGridView1.Columns[3].Width = 120; this.dataGridView1.Columns[4].Width = 120; Customize Cells and Columns in the Windows Forms DataGridView Control by Extending Their Behavior and Appearance Host Controls in Windows Forms DataGridView Cells 继承 DataGridViewTextBoxCell 类生成新的Cell类,然后再继承 DataGridViewColumn 生成新的Column类,并指定 CellTemplate为新的Cell类。新生成的Column便可以增加到DataGridView中去。 2、自动适应列宽 Programmatically Resize Cells to Fit Content in the Windows Forms DataGridView Control Samples: DataGridView.AutoSizeColumns( DataGridViewAutoSizeColumnCriteria.HeaderAndDisplayedRows); DataGridView.AutoSizeColumn( DataGridViewAutoSizeColumnCriteria.HeaderOnly, 2, false); DataGridView.AutoSizeRow( DataGridViewAutoSizeRowCriteria.Columns, 2, false); DataGridView.AutoSizeRows( DataGridViewAutoSizeRowCriteria.HeaderAndColumns, 0, dataGridView1.Rows.Count, false); 3、可以绑定并显示对象 Bind Objects to Windows Forms DataGridView Controls 4、可以改变表格线条风格 Change the Border and Gridline Styles in the Windows Forms DataGridView Control Samples: this.dataGridView1.GridColor = Color.BlueViolet; this.dataGridView1.BorderStyle = BorderStyle.Fixed3D; this.dataGridView1.CellBorderStyle = DataGridViewCellBorderStyle.None; this.dataGridView1.RowHeadersBorderStyle = DataGridVie

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值