我试图从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>
请帮助我,为什么我无法获得复选框值
答案 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();
}
}