2012-04-25 80 views
0

我正在以编程方式创建一个数据网格,并且我想将已从用户更改过的单元格的值添加到另一个数据网格中。datagrid cellvaluechanged动态对象的事件处理程序

我的代码是这样的:

connTo.Open(); 

SqlDataReader sqlFromReader1 = null; 
SqlDataReader sqlFromReader2 = null; 
SqlDataReader sqlFromReader3 = null; 

SqlCommand myFromCommand1 = new SqlCommand("select distinct m.catid1, c.descr "+ 
"from material m "+ 
"inner join cat1 c on c.id = m.catid1", connTo); 
sqlFromReader1 = myFromCommand1.ExecuteReader(); 

DataTable dt1 = new DataTable(); 
dt1.Load(sqlFromReader1); 

for (i = 0; i < dt1.Rows.Count; i++) 
{ 
    //int c1 = (int)(dt1.Rows[i]["catid1"]); 
    TabPage tbg = new TabPage(dt1.Rows[i]["descr"].ToString()); 
    tabControl1.Controls.Add(tbg); 

    TabControl tbi = new TabControl(); 
    tbi.Name = i.ToString() + i.ToString(); 

    SqlCommand myFromCommand2 = new SqlCommand(
     "select distinct m.catid2, c.descr " + 
     "from material m " + 
     "inner join cat2 c on c.id = m.catid2 "+ 
     "and m.catid1 = " + dt1.Rows[i]["catid1"].ToString(), connTo); 
     sqlFromReader2 = myFromCommand2.ExecuteReader(); 

    DataTable dt2 = new DataTable(); 
    dt2.Load(sqlFromReader2); 

    for (int k = 0; k < dt2.Rows.Count; k++) 
    { 
     //int c2 = (int)(dt2.Rows[k]["catid2"]); 
     TabPage tbgi = new TabPage(dt2.Rows[k]["descr"].ToString()); 
     tbi.Controls.Add(tbgi); 
     tbi.Left = 1; 
     tbi.Top = 1; 
     tbi.Width = 880; 
     tbi.Height = 400; 


     DataGridView gv = new DataGridView(); 

     gv.Width = 850; 
     gv.Height = 340;    
     gv.Left = 10; 
     gv.Top = 10; 
     gv.ColumnCount = 4; 
     gv.Columns[0].Name = "code"; 
     gv.Columns[0].Width = 120; 
     gv.Columns[0].ReadOnly = true; 

     gv.Columns[1].Name = "name"; 
     gv.Columns[1].Width = 450; 
     gv.Columns[1].ReadOnly = true; 

     gv.Columns[2].Name = "price"; 
     gv.Columns[2].Width = 80; 
     gv.Columns[2].ReadOnly = true; 

     gv.Columns[3].Name = "qty"; 
     gv.Columns[3].Width = 120; 

     SqlCommand myFromCommand3 = new SqlCommand(
      "select m.code, m.descr, m.cost1 price " + 
      "from material m " + 
      "where m.catid1 = " + dt1.Rows[i]["catid1"].ToString() + " " + 
      "and m.catid2 = " + dt2.Rows[k]["catid2"].ToString(), connTo); 

     sqlFromReader3 = myFromCommand3.ExecuteReader(); 

     DataTable dt3 = new DataTable(); 
     dt3.Load(sqlFromReader3); 

     for (int l = 0; l < dt3.Rows.Count; l++) 
     { 
      gv.Rows.Add(dt3.Rows[l]["code"].ToString(), dt3.Rows[l]["descr"].ToString(), dt3.Rows[l]["price"].ToString(), ""); 
     } 

     tbgi.Controls.Add(gv);      
    } 
    tbg.Controls.Add(tbi); 

现在我想,当用户改变gv.Columns的价值赶上[3],请将.Name(“数量”)来添加这个值和的休息将行数据转换为新的数据列表。

这怎么办?这可能吗?

+0

我不确定我是否理解你的问题,因为你在问题标题中提到的事件正是我相信会帮助你的事情。我会回答,但如果这没有帮助,请尝试进一步解释问题。另外,您可以使用dt3作为datagridview的数据源,而不是像现在这样创建行。 – 2012-04-25 22:21:40

回答

0

CellValueChanged事件应该在这种情况下工作。

当您创建的每个新DataGridView实例,并将其添加到选项卡只需添加一个事件处理程序:

dataGridView1.CellValueChanged += new DataGridViewCellEventHandler(dataGridView1_CellValueChanged); 

这时你所使用的所有的事件处理程序在一个地方的方法dataGridView1_CellValueChanged

CellValueChanged事件处理程序的签名采用DataGridViewCellEventArgs,它对于已更改的列索引和行索引都具有属性。所以你有这样的代码:

void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e) 
{ 
    if (e.ColumnIndex == 3) 
    { 
     // Now you can cast sender to a DataGridView and copy the row at e.RowIndex 
     DataGridView dgv = sender as DataGridView; 
     if (dgv == null) 
      return; 

     // Here you get the cell value 
     var cellValue = dgv.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString(); 
    } 
} 

我也建议分配dt3作为数据源。如果您确实使用数据源而不是未绑定的网格,则该行的复制将变得更清晰。

+0

好的,但我怎么能有列的值,所以我可以复制它们? – 2012-04-26 05:44:10

+0

查看编辑答案 – 2012-04-26 08:41:26

相关问题