2013-03-10 61 views
0

在我的代码中,我有一个CheckboxList,我动态地添加它的项目!我想要的是保存文本,但只从选中复选框在会话中,因为我将在我的下一个表格中需要它!例外'索引超出范围'

所以我想提出一些文本,当你看到我保存在与名myche列表从选中的复选框的文本,但是,当我按下按钮,看到这份名单的第一个项目 - 此代码lblProba.Text = myche[0];给我一个例外'索引超出范围'。看来我的清单是空的。

public partial class FormEGN : System.Web.UI.Page 
{ 
    string mynewstring; 
    //List<List<string>> mycheckedList = new List<List<string>>(); 
    List<string> myche = new List<string>(); 
    CheckBoxList mycheckbox = new CheckBoxList(); 
    protected void Page_Load(object sender, EventArgs e) 
    { 
     mynewstring = (string)Session["id2"]; 


     if(!IsPostBack) 
     { 
      ddlNumberTourists.Items.Add("1"); 
      ddlNumberTourists.Items.Add("2"); 
      ddlNumberTourists.Items.Add("3"); 
     } 
    } 

    protected void btnProba_Click(object sender, EventArgs e) 
    { 
     lblProba.Text = myche[0]; 
    } 

    protected void btnReserve_Click(object sender, EventArgs e) 
    { 
     string num =Request.QueryString["ExcursionID"]; 
     Response.Redirect(String.Format("ClintsInformation.aspx?Excursiondate_ID={0}",num)); 

    } 

    protected void ddlNumberTourists_SelectedIndexChanged(object sender, EventArgs e) 
    { 

     int numTourists = Convert.ToInt32(ddlNumberTourists.SelectedItem.Text); 
     for (int i = 0; i < numTourists; i++) 
     { 

      Label myLabel = new Label(); 
      myLabel.ID = "lblAccomodation" + (i + 1).ToString(); 
      myLabel.Text = "Настаняване Турист" + (i + 1).ToString(); 
      Page.FindControl("form1").Controls.Add(myLabel); 
      DropDownList myDropDownList = new DropDownList(); 
      myDropDownList.ID = "ddlTourist" + i.ToString(); 
      Page.FindControl("form1").Controls.Add(myDropDownList); 
      Page.FindControl("form1").Controls.Add(new LiteralControl("<br />")); 

      string connectionString = "Server=localhost\\SQLEXPRESS;Database=EXCURSIONSDATABASE;Trusted_Connection=true"; 
      string query = 
     "SELECT Extra_Charge_ID, Excursion_ID, Amout, Extra_Charge_Description FROM EXTRA_CHARGES WHERE Excursion_ID=" + mynewstring; 
      SqlConnection conn = new SqlConnection(connectionString); 
      SqlCommand cmd = new SqlCommand(query, conn); 

      try 
      { 
       conn.Open(); 
       SqlDataReader rd = cmd.ExecuteReader(); 
       int s = 0; 

       while (rd.Read()) 
       { 
        mycheckbox.ID = "chkblextracharge" + i.ToString() + s.ToString(); 
        mycheckbox.Items.Add(rd["Extra_Charge_Description"].ToString()); 
        Page.FindControl("form1").Controls.Add(mycheckbox); 

        if (mycheckbox.Items[s].Selected == true) 
        { 
         myche.Add(mycheckbox.Items[s].Text); 
        } 
        s++; 
       } 

      }//End of try 

      catch (Exception ex) 
      { } 
      Session["chk"] = myche; 

     }//end of for 
    } 
} 
+0

请正确格式化您的代码,删除无意义的空白行。 – Lion 2013-03-10 07:23:09

+0

@Lion - 您有足够的声誉进行编辑并向OP显示正确的方式。 – Oded 2013-03-10 07:24:18

+0

请只发布_relevant_代码 - 发布所有这些代码只是很难找出问题 - 比如导致错误和相关代码的_line_。我建议遵循[sscce](http://sscce.org)的指导方针 – Oded 2013-03-10 07:28:23

回答

0

问题之前空是myche中有没有项目的按钮单击事件处理程序被触发时。

唯一的地方你实际上任何项目的名单是ddlNumberTourists_SelectedIndexChanged。此事件处理程序是而不是在回发后调用,因此myche为空。

如果您希望在回发之间保留myche的值,您需要在视图状态下存储和加载myche的值。

我建议您阅读关于ASP.NET page life cycle以及TRULY Understanding ViewState如果您想了解如何使其正常工作。款式


注:

try 
{ 
    //something 
} 
catch (Exception ex) 
{ } 

是可怕的做法 - 如果抛出一个异常,你永远不知道这件事。

+0

问题不仅在于这个Oded - 当然是我!我的事情(mycheckbox.Items [s] .Selected始终是false,因为当我在创建时动态创建它们时,它们不会被检查!我认为这是第一个问题。 – 2013-03-10 10:28:25

+0

@MilkaSalkova - 好吧,有很多事情要指出出来,但我建议先阅读这两篇文章 – Oded 2013-03-10 10:39:08

+0

是的,我读他们,我婉在会话中存储的检查项目的文本 - 我和会议工作,我想尝试 - 所以当我忽略这一点,如果(mycheckbox.Items [s] .Selected == true),并将所有复选框的文本存储在一个会话中 - 它的工作原理完美。或许我的新问题是我应该检查项目是否被检查。如果你能帮助我会很高兴 – 2013-03-10 10:45:39