2013-02-28 97 views
6

我创建了labelstextboxes动态。一切顺利,但第二个label不想出现。我错在哪里?这是我在C#中的代码:我错了?动态创建标签c#

private void checkedListBox1_SelectedIndexChanged(object sender, EventArgs e) 
{ 
    OracleDataReader reader; 
    int x = 434; 
    int y = 84; 
    int i = 0; 
    try 
    { 
     conn.Open(); 

     foreach (var itemChecked in checkedListBox1.CheckedItems) 
     { 
      Label NewLabel = new Label(); 
      NewLabel.Location = new Point(x + 100, y); 
      NewLabel.Name = "Label" + i.ToString(); 
      Controls.Add(NewLabel); 
      TextBox tb = new TextBox(); 
      tb.Location = new Point(x, y); 
      tb.Name = "txtBox" + i.ToString(); 
      Controls.Add(tb); 
      y += 30; 
      OracleCommand cmd = new OracleCommand("SELECT distinct data_type from all_arguments where owner='HR' and argument_name='" + itemChecked.ToString() + "'", conn); 


      reader = cmd.ExecuteReader(); 

      while (reader.Read()) 
      { 
       label[0].Text = reader["data_type"].ToString(); 
      } 

      i++; 
     } 
    } 
    finally 
    { 
     if (conn != null) 
      conn.Close(); 
    } 
} 

private void Procedure() 
{ 
    string proc = ""; 
    try 
    { 
     conn.Open(); 

     if (this.listView1.SelectedItems.Count > 0) 
      proc = listView1.SelectedItems[0].Text; 

     OracleCommand cmd = new OracleCommand("" + proc + "", conn); 
     cmd.CommandType = CommandType.StoredProcedure; 
     cmd.CommandTimeout = 600; 

     int i = 0; 
     foreach (var itemChecked1 in checkedListBox1.Items) 
     { 
      Control[] txt = Controls.Find("txtBox" + i.ToString(), false); 
      Control[] label = Controls.Find("Label" + i.ToString(), false); 
      cmd.Parameters.Add(new OracleParameter("select distinct data_type from all_arguments where owner='HR' and argument_name=toupper("+itemChecked1.ToString()+")",conn)); 
      cmd.Parameters[":"+itemChecked1.ToString()+""].Value=label[0].Text; 
      cmd.Parameters.Add(new OracleParameter(":" + itemChecked1.ToString() + "", OracleDbType.Varchar2)); 
      cmd.Parameters[":" + itemChecked1.ToString() + ""].Value = txt[0].Text; 

      i++; 
+1

查看html并验证标签是否存在。如果是,请使用浏览器的开发工具手动调整CSS。 IE9具有体面的内置工具,只需按F12即可。 – 2013-02-28 13:53:50

+5

“我错了?”除了SQL注入外,魔术变量名称为:int x = 434; int y = 84;',而且你正在为每个* checked项目运行select语句?为什么你创建一个标签只是为了转身找到它?直言不讳,我认为你应该描述你正在尝试做什么,这样我们可以抛出这些代码并重新开始。 – aquinas 2013-02-28 14:06:42

+2

我设法做到这一点,通过在这里发布的人,但我不知道他为什么删除帖子。我将这两行代码中的标签替换为其他内容:Control [] label = Controls.Find(“Label”+ i.ToString(),false);和NewLabel.Name =“Label”+ i.ToString(); – Viva 2013-02-28 14:14:05

回答

1

我认为第二个Label已经出现。但它的文本是一个空字符串!所以你永远不会看到它。 检查数据库阅读器返回的“data_type”。