Form DataGridView绑定BindingSource的几种方式

本文链接:https://blog.csdn.net/qq_15138169/article/details/83341076

在WinForm的开发中,ListView和DataGridView应用的场景都比较,初学的时候绑定数据都是用最简单的一种方式去实现

  1. private void NormalAdd()
  2. {
  3. dataGridView1.Rows.Clear();
  4. for (int i = 0; i < 10; ++i)
  5. {
  6. int index = dataGridView1.Rows.Add();
  7. dataGridView1.Rows[index].Cells[0].Value = i+"elem1";
  8. dataGridView1.Rows[index].Cells[1].Value = i+"elem2";
  9. dataGridView1.Rows[index].Cells[2].Value = i+"elem3";

dataGridView1.Rows[index].Cells[2].Value = i+"elem4";

上面的方法其实是最直观的,但是微软还提供其他几种比较优雅一些的方式去绑定数据,就是通过BindingSource来实现,BindingSource看名字就知道干啥用的了。

public List<ItemBean> list = new List<ItemBean>();

private void dataList()

{

for (int i = 0; i < 10; ++i)

{

ItemBean item = new ItemBean();

item.postion = i.ToString();

item.item1 = "Listitem1-" + i;

item.item2 = "Listitem2-" + i;

item.item3 = "Listitem3-" + i;

list.Add(item);

}

bindingSource1.DataSource = list;

//DataGridView的列name和对象成员的绑定

dataGridView1.Columns["Column1"].DataPropertyName = "postion";

dataGridView1.Columns["Column2"].DataPropertyName = "item1";

dataGridView1.Columns["Column3"].DataPropertyName = "item2";

dataGridView1.Columns["Column4"].DataPropertyName = "item3";

}

public class ItemBean

{

public string postion { get; set; }

public string item1 { get; set; }

public string item2 { get; set; }

public string item3 { get; set; }

}

这种是List数据源方式实现绑定

public DataTable dt = new DataTable("ITEMBEAN");

private void dataTable()

{

dt.Columns.Add("POS", typeof(string));

dt.Columns.Add("ITEM1", typeof(string));

dt.Columns.Add("ITEM2", typeof(string));

dt.Columns.Add("ITEM3", typeof(string));

for (int i = 0; i < 10; ++i)

{

DataRow dr = dt.NewRow();

dr[0] = i.ToString();

dr[1] = i.ToString() + "_Table单元1";

dr[2] = i.ToString() + "_Table单元2";

dr[3] = i.ToString() + "_Table单元3";

dt.Rows.Add(dr);

}

bindingSource1.DataSource = dt;

dataGridView1.Columns["Column1"].DataPropertyName = "POS";

dataGridView1.Columns["Column2"].DataPropertyName = "ITEM1";

dataGridView1.Columns["Column3"].DataPropertyName = "ITEM2";

dataGridView1.Columns["Column4"].DataPropertyName = "ITEM3";

}

这个的是DataTable的方式,其他的还有几种,大家可以自己去试一试,这两种的在实际项目中应用场景应该比较多一些。

原文地址:https://www.cnblogs.com/wfy680/p/12004514.html

时间: 2024-10-03 22:53:05

Form DataGridView绑定BindingSource的几种方式的相关文章

【转】DataGridView绑定数据源的几种方式

第一种:DataSet ds=new DataSet (); this.dataGridView1.DataSource=ds.Table[0]; 第二种:DataTable dt=new DataTable(); this.dataGridView1.DataSource=dt; 第三种:DataSet ds=new DataSet (); this.dataGridView1.DataSource = ds.Tables["表名"]; 第四种:DataSet ds=new Data

jQuery绑定事件的四种方式:bind、live、delegate、on

1.jQuery操作DOM元素的绑定事件的四种方式 jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off. 2.必备的基础知识: DOM树 示例,这是在browser环境下的一棵模拟DOM树: 我们的页面可以理解为一棵DOM树,当我们在叶子结点上做什么事情的时候(如click一个a元素),如果我们没有人为的设置stopPropagation(Moder Browser), cancel

jQuery绑定事件的四种方式

jQuery绑定事件的四种方式 jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码.下面我们来看下jQuery中绑定事件的方式都有哪些. jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off.在开始看他们之前 一:bind(type,[data],function(eventObject

[微信小程序] 微信小程序下拉滚动选择器picker绑定数据的两种方式

微信小程序下拉滚动选择器picker绑定数据的两种方式  本地数据绑定和wx.request(OBJECT) json数据绑定 1.本地数据绑定 (对象数组) Page({ data:{ //户型 这是一个本地的对象,然后绑定到页面上 pic_array: [ { id: 13, name: '1室1厅1卫' }, { id: 14, name: '1室2厅1卫' }, { id: 15, name: '2室1厅1卫' }, { id: 16, name: '3室1厅2卫' }, { id: 1

jQuery绑定事件的四种方式区别

jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off.在开始看他们之前 一:bind(type,[data],function(eventObject)) bind是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义如下: type:事件类型,如click.change.mouseover等; data:传入监听函数的参数,通过event.data取到.

jq绑定事件的4种方式

jQuery提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码.下面我们来看下jQuery中绑定事件的方式都有哪些. jQuery中提供了四种事件监听方式,分别是bind.live.delegate.on,对应的解除监听的函数分别是unbind.die.undelegate.off.在开始看他们之前,先来声明一个例子,各函数的用法将围绕这个例子进行,html代码如下: 列表元素1 列表元素2 列表元素3 列表

C#中DataGridView控件绑定数据源有几种方式?

第一种:DataSet ds=new DataSet (); this.dataGridView1.DataSource=ds.Table[0]; 第二种:DataTable dt=new DataTable(); this.dataGridView1.DataSource=dt; 第三种:DataSet ds=new DataSet (); this.dataGridView1.DataSource = ds.Tables["表名"]; 第四种:DataSet ds=new Data

Winform控件DataGridView添加数据的几种方式

1:直接添加 在控件中设置好每列的名称 例如: DataGridViewRow row = new DataGridViewRow(); int j = dgv.Rows.Add(row); dgv.Rows[j].Cells[1].Value = 值; dgv.Rows[j].Cells[2].Style.Font = new Font(dgv.Font, FontStyle.Bold);//设置字体加粗 2:数据源绑定 当加载数据量比较大时,使用第一种方法由于每次都要新建行,可能导致加载数据

asp.net 登陆验证 Form表单验证的3种方式 FormsAuthentication.SetAuthCookie;FormsAuthentication.RedirectFromLoginPage;FormsAuthenticationTicket

我们在登陆成功后,使用下面的3种方法,都是同一个目的:创建身份验证票并将其附加到 Cookie, 当我们用Forms认证方式的时候,可以使用HttpContext.Current.User.Identity.IsAuthenticated  (或者也可以用 Request.IsAuthenticated ,这个实际上也是调用的是User.Identity.IsAuthenticated来验证)来判断是否登陆;而这个判断就是依赖于这个Cookie里的信息判断用户是否登陆. FormsAuthent