我在经典ASP中的ASPX-WebForm上有一个GridView,其中包含CSV-Export的客户信息。
在这个GridView中,我在TemplateField中有一个用户选择的复选框。 在ClickEvent的CodeBehind中,我通过GridView的行使用ForEach-Loop,并且想要检查自生成(数据来自数据库)复选框(如果选中)。使用FindCOntrol我可以取消选中复选框,直到有一切都可以。但是,虽然在Webform上检查了每个Checkbox,但不会检查它们。
谁能告诉我我做错了什么?
ASPX:
<body>
<form id="form1" runat="server">
<div>
<asp:GridView ID="GridViewAdressen" runat="server" AutoGenerateColumns="false" DataKeyNames="order_id" EnablePersistedSelection="true" style="width:100%;" PagerSettings-Mode="Numeric">
<Columns>
<asp:TemplateField HeaderText="Auswahl">
<ItemTemplate>
<input type="checkbox" name="chkSelect" runat="server"/>
</ItemTemplate>
</asp:TemplateField>
<asp:BoundField HeaderText="ID" DataField="order_id"/>
<asp:BoundField HeaderText="Zeit" DataField="zeitpunkt"/>
<asp:BoundField HeaderText="Preis" DataField="preis"/>
<asp:BoundField HeaderText="Name" DataField="name"/>
<asp:BoundField HeaderText="Nick" DataField="username"/>
</Columns>
</asp:GridView>
<asp:Button Text="CSV erstellen" runat="server" OnClick="Unnamed_Click"/>
</div>
</form>
代码隐藏:
protected void Page_Load(object sender, EventArgs e)
{
if (Request.QueryString["security"] != null && Request.QueryString["security"] == token.seitenSicherheit)
{
// Anzahl Adressen
string menge = "10";
if (Request.QueryString["menge"] != null)
{
menge = Request.QueryString["menge"];
}
DataTable table = new DataTable();
using (OdbcConnection connection = new OdbcConnection(ConfigurationManager.ConnectionStrings["MySQLConnStr"].ConnectionString))
{
connection.Open();
using (OdbcCommand command = new OdbcCommand("SELECT * FROM bestellvorgang order by zeitpunkt desc limit " + menge, connection))
{
using (OdbcDataAdapter ad = new OdbcDataAdapter(command))
{
ad.Fill(table);
}
}
}
GridViewAdressen.DataSource = table;
GridViewAdressen.DataBind();
}
else
{
Response.Write("Keine Zugangsberechtigung");
}
}
protected void Unnamed_Click(object sender, EventArgs e)
{
// string für csv erstellen
// Grid View durchlaufen und checkBox prüfen
foreach (GridViewRow row in GridViewAdressen.Rows)
{
HtmlGenericControl chk = (HtmlGenericControl)row.FindControl("chkSelect");
if (chk.Checked)
{
// Abfrage für den order_id
Response.Write("Order-ID: " + GridViewAdressen.DataKeys[row.RowIndex].Value);
}
}
}
与FINDCONTROL进行UNBOXING并非空,但从未检查过!!!!!!!
或者我尝试使用Html输入复选框但是当使用FindControl和unbox作为HtmlGenericControl时,它总是为NULL ....
答案 0 :(得分:1)
您应该将GridView的DataBinding包装在IsPostBack检查
中protected void Page_Load(object sender, EventArgs e)
{
if (Request.QueryString["security"] != null && Request.QueryString["security"] == token.seitenSicherheit)
{
if (IsPostBack == false)
{
//rest of your code
GridViewAdressen.DataSource = table;
GridViewAdressen.DataBind();
}
}
else
{
Response.Write("Keine Zugangsberechtigung");
}
}
如果不这样做,每个PostBack都会反弹数据,这会使任何更改(如检查CheckBox)重置为默认值。