未从网格视图捕获复选框值

时间:2013-11-18 13:42:11

标签: c# asp.net

我试图从GridView获取读取值并上传到数据库

我能够读取文本值但无法获取GridView CheckBox值。

在asp.C#

中运行以下代码时,我只在数据库表中获得false (0)

按钮事件中的我的代码如下: -

    protected void btnSave_Click(object sender, EventArgs e)
    {
        btnSave.Visible = false;
        btnEdit.Visible = true;
        int i = 0;
        string defaultvalue = "0";
        foreach (GridViewRow row in grdExtApp.Rows)
        {
            string qry = "INSERT into tb_externalsystemaccess(User_Id,     SystemName,Access_status) VALUES (@v1, @v2, @v3)";
            SqlConnection con = new SqlConnection(str);
            using (SqlCommand cmd = new SqlCommand(qry, con))
            {
                cmd.Parameters.AddWithValue("@v1", TextBox3.Text);    
                cmd.Parameters.Add("@v2", SqlDbType.Text).Value = Convert.ToString    (row.Cells[0].Text);
                CheckBox chkBx = (CheckBox)row.FindControl("AccessExternal");
                if (chkBx.Checked)
                {
                    defaultvalue = "1";
                }
                cmd.Parameters.Add("@v3", SqlDbType.Bit).Value = Convert.ToInt16    (defaultvalue);
                con.Open();
                cmd.ExecuteNonQuery();
                i = i + 1;

            }
        }
    }

我从TextBox控件外部获取v1值。

v2值来自GridView单元..它是一个字符串值,我能够捕获它

v3值是CheckBox值..它无法捕获..即使我检查CheckBox,也只显示为false。

我对GridView的标记如下所示:

     <asp:GridView ID="grdExtApp" runat="server" 
                AutoGenerateColumns="False" BackColor="White">
                          <Columns>
                          <asp:BoundField DataField="External_System"       HeaderText="External System" />  



                  <asp:TemplateField HeaderText="Access">  

                      <ItemTemplate>  

                          <asp:CheckBox ID="AccessExternal" runat="server"      Enabled="true" />  

                   </ItemTemplate>  

                 </asp:TemplateField>  


                          </Columns>

            </asp:GridView>

请帮助我,为什么我无法获得复选框值

2 个答案:

答案 0 :(得分:3)

btn_Save()是一种回发方法,我在你的Form_Load()中假设你总是重新绑定你的网格,从而清除你选中的复选框。

您应该将此设置在Form_Load()

的顶部
if (!Page.IsPostBack)
    {
        grdExtApp.DataSourceID = "yourDatasourceID";
        grdExtApp.DataBind();
    }

答案 1 :(得分:0)

Protected void btnSave_Click(object sender, EventArgs e)
    {
        btnSave.Visible = false;
        btnEdit.Visible = true;
        //int i = 0;
        //string defaultvalue = "0";

         string qry = "INSERT into tb_externalsystemaccess(User_Id,SystemName,Access_status) VALUES (@v1, @v2, @v3)";
            SqlConnection con = new SqlConnection(str);
              for (int i = 0; i < grdExtApp.Rows.Count; i++)
            {

                GridViewRow row = grdExtApp.Rows[i];
                bool defaultvalue  = ((CheckBox)row.FindControl("AccessExternal")).Checked;
                cmd.Parameters.AddWithValue("@v1", TextBox3.Text);    
                cmd.Parameters.Add("@v2", SqlDbType.Text).Value = Convert.ToString(row.Cells[0].Text);
                cmd.Parameters.Add("@v3", SqlDbType.Bit).Value =defaultvalue;
                con.open();
                cmd.ExecuteNonQuery();
                con.Close();
                con.Dispose();

            }

    }