0

我在更新面板中使用了 5 个单选按钮,但是当我第一次检查单选按钮时,它不会被选中更改。之后意味着第二次检查它的工作正常,所以请告诉应该是什么问题。这是我的代码

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
   <ContentTemplate>
       <asp:RadioButton ID="rbtn_A" runat="server" GroupName="rbt" 
            AutoPostBack="true" OnCheckedChanged="rbtn_A_CheckedChanged" />
       <asp:RadioButton ID="rbtn_B" runat="server" GroupName="rbt" AutoPostBack="true"
            OnCheckedChanged="rbtn_B_CheckedChanged" />
       <asp:RadioButton ID="rbtn_C" runat="server" GroupName="rbt" AutoPostBack="true" 
            OnCheckedChanged="rbtn_C_CheckedChanged" />
       <asp:RadioButton ID="rbtn_D" runat="server" GroupName="rbt" AutoPostBack="true" 
            OnCheckedChanged="rbtn_D_CheckedChanged" />
   </ContentTemplate>

这是我的第一个单选按钮 c# 函数:protected void rbtn_A_CheckedChanged(object sender, EventArgs e) {

        foreach (GridViewRow gv in dl_ques.Rows)
        {
            Label lblTest = (Label)gv.FindControl("lbltest");
            Label lbl = (Label)gv.FindControl("lbl_qno");
            RadioButton rbtn_A = (RadioButton)gv.FindControl("rbtn_A");
            DataSet ds = new DataSet();
            ds = getAnswer();
            SqlCommand cmd1 = DataManager.getCommandSp("spGetIBPSTestQues");
            cmd1.Parameters.AddWithValue("@Test_id", Convert.ToInt32(lblTest.Text));
            DataSet dsorg = DataManager.getDataSet(cmd1);
            if (ds.Tables[0].Rows.Count > 0)
            {
                SqlCommand cmd = new SqlCommand();
                cmd = DataManager.getCommandSp("SpUpdateIBPSTestSolved");
                cmd.Parameters.AddWithValue("@user_id", Convert.ToInt32(ht["UId"]));

                cmd.Parameters.AddWithValue("@Ans", "A");
                foreach (DataRow dr in dsorg.Tables[0].Rows)
                {
                    if (Convert.ToInt32(lbl.Text) == Convert.ToInt32(dr["actual_que"]))
                    {
                        if (dr["actual_ans"].ToString() == "A")
                        {
                            cmd.Parameters.AddWithValue("@Ans_correct", "Yes");
                        }
                        else
                        {
                            cmd.Parameters.AddWithValue("@Ans_correct", "No");
                        }
                    }
                }
                cmd.Parameters.AddWithValue("@test_id", Convert.ToInt32(lblTest.Text));
                cmd.Parameters.AddWithValue("@Test_dt", DateTime.Now);
                cmd.Parameters.AddWithValue("@Ques_id", lbl.Text);
                cmd.Parameters.AddWithValue("@LastTimeMin", timehdnmin.Value);
                cmd.Parameters.AddWithValue("@LastTimeSec", timehdnsec.Value);

                DataManager.WriteToDb(cmd);

            }
            else
            {
                SqlCommand cmd = new SqlCommand();
                cmd = DataManager.getCommandSp("SpInsertIBPSTestSolved");
                cmd.Parameters.AddWithValue("@user_id", Convert.ToInt32(ht["UId"]));

                cmd.Parameters.AddWithValue("@Ans", "A");
                foreach (DataRow dr in dsorg.Tables[0].Rows)
                {
                    if (Convert.ToInt32(lbl.Text) == Convert.ToInt32(dr["actual_que"]))
                    {
                        if (dr["actual_ans"].ToString() == "A")
                        {
                            cmd.Parameters.AddWithValue("@Ans_correct", "Yes");
                        }
                        else
                        {
                            cmd.Parameters.AddWithValue("@Ans_correct", "No");
                        }
                    }
                }

                cmd.Parameters.AddWithValue("@test_id", Convert.ToInt32(lblTest.Text));
                cmd.Parameters.AddWithValue("@Test_dt", DateTime.Now);
                cmd.Parameters.AddWithValue("@Ques_id", lbl.Text);
                cmd.Parameters.AddWithValue("@LastTimeMin", timehdnmin.Value);
                cmd.Parameters.AddWithValue("@LastTimeSec", timehdnsec.Value);

                DataManager.WriteToDb(cmd);
            }
        }
    }
4

3 回答 3

1

默认情况下,您需要checked在页面加载时将单选按钮之一设为 true

<asp:RadioButton ID="rbtn_A" runat="server" AutoPostBack="True" GroupName="rbt"
OnCheckedChanged="rbtn_A_CheckedChanged" Checked="True" />

根据你所说的尝试这个

if(!Page.IsPostback)
{
  rbtn_A.Checked = true;
}
于 2013-02-25T06:20:51.320 回答
1

我知道这是一个旧帖子,但希望这对其他人有帮助。

对我来说,这不是页面上发生的事情,而是我进入页面的方式。

我正在使用 导航到页面Server.Transfer("~/MyPage.aspx");

更改以Response.Redirect("~/MyPage.aspx");解决我的问题。

于 2019-04-23T19:04:17.463 回答
0

将所有单选按钮设置为Checked=False;可能会对您有所帮助

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
 <ContentTemplate>
   <asp:RadioButton ID="rbtn_A" runat="server" GroupName="rbt" 
        AutoPostBack="true" OnCheckedChanged="rbtn_A_CheckedChanged" Checked="False" />
   <asp:RadioButton ID="rbtn_B" runat="server" GroupName="rbt" AutoPostBack="true"
        OnCheckedChanged="rbtn_B_CheckedChanged" Checked="False"/>
   <asp:RadioButton ID="rbtn_C" runat="server" GroupName="rbt" AutoPostBack="true" 
        OnCheckedChanged="rbtn_C_CheckedChanged" Checked="False"/>
   <asp:RadioButton ID="rbtn_D" runat="server" GroupName="rbt" AutoPostBack="true" 
        OnCheckedChanged="rbtn_D_CheckedChanged" Checked="False"/>
 </ContentTemplate>
于 2013-02-25T12:06:27.237 回答