0

在我的函数createCheckboxes() 中,我动态地创建了复选框——它们都带有分配的checkedChanged事件。

在事件处理程序中,我测试是否选中了复选框,如果是,我会在会话中破坏 value 属性。

但是例如,如果客户决定选中一个复选框并将 alue 添加到会话中,但随后他突然决定要取消选中该复选框 - 所以我应该从数组列表中删除该值,然后从会话中删除。

最大的问题是,当取消选中 Checkedchanged 事件处理程序时似乎永远不会执行,并且此代码永远不会执行

else if (!chk.Checked)
        {
             lblProba.Text += "You wll be delited";
            for (int i = 0; i < element.Count; i++)
            {

                if (element[i].ToString().Equals(chk.InputAttributes["value"]) == true)

                    element.Remove(element[i]);
            }

        }

我的完整代码


        protected void checkChanged(object sender, EventArgs e)
{
        CheckBox chk = (CheckBox)sender;
        if (chk.Checked)
        {
            element.Add(chk.InputAttributes["value"]);

        }

        else if (!chk.Checked)
        {
             lblProba.Text += "You wll be delited";
            for (int i = 0; i < element.Count; i++)
            {

                if (element[i].ToString().Equals(chk.InputAttributes["value"]) == true)

                    element.Remove(element[i]);
            }

        }

            for (int t = 0; t < element.Count; t++)
        { 
            Session["chk"]+= element[t].ToString(); 

        }


}
        protected void createCheckboxes()
        {
            chkddlchange = true;
            int numTourists = 2;
            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=excursion;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())
                    {   
                        CheckBox mycheckbox = new CheckBox();
                        mycheckbox.ID = "chkblextracharge" + i.ToString() + s.ToString();
                       mycheckbox.Text = rd["Extra_Charge_Description"].ToString();
                       mycheckbox.InputAttributes.Add("value", rd["Extra_Charge_ID"].ToString());

                       mycheckbox.AutoPostBack = true;
                       mycheckbox.EnableViewState =true ;
                       mycheckbox.CheckedChanged += new EventHandler(checkChanged);
                       Page.FindControl("form1").Controls.Add(mycheckbox);


                        s++;

                    }

                       //myche.Add(mycheckbox.Items[s].Text);


                }//End of try

                catch (Exception ex)
                { }


            }//end of for


        }




    }
}
4

1 回答 1

1

Autopostback=true在创建复选框时是否提到过?如果不是,请执行此操作,看看它是否有效。

于 2013-06-20T07:11:42.610 回答