我的 SQL 表中有 8 个项目,其中包含描述、项目编号和图像路径。
protected void Page_Load(object sender, EventArgs e)
{
//fill the datalist for the Signs Table
string tCallFrom = "Program." + System.Reflection.MethodBase.GetCurrentMethod().Name;
string tQry = @"SELECT * FROM [js_Signs]";
DataTable tblSigns = objCommMethods.fReturnTableFromQry(clsDBSelect.enumDBSelect.ProjectMaster, tQry, tCallFrom);
SignsList.DataSource = tblSigns;
SignsList.DataBind();
}
我使用 DataList 来显示所有项目以及一个文本框,该文本框允许用户输入他们想要的项目数量:
<asp:DataList ID="SignsList" runat="server" RepeatColumns="4" CellPadding="2" Width="90%" ItemStyle-HorizontalAlign="Center">
<ItemTemplate>
<table>
<tr>
<th>
<%#DataBinder.Eval(Container.DataItem, "Description") %>
</th>
</tr>
<tr>
<th>
<%#DataBinder.Eval(Container.DataItem, "ItemNumber") %>
</th>
</tr>
<tr>
<td>
<asp:Image ID="SignImage" runat="server" ImageUrl='<%#DataBinder.Eval(Container.DataItem, "ImagePath") %>' />
</td>
</tr>
<tr style="text-align: center;">
<td>
<asp:TextBox ID="txtSignQuantity" runat="server" CssClass="txtBox" BackColor="White" Enabled="true"
type="number" min="0" ToolTip="Please choose quantity of signs needed."/>
</td>
</tr>
<tr>
<td>
<p> </p>
</td>
</tr>
</table>
</ItemTemplate>
</asp:DataList>
<div class="btnGroup">
<div class="btnDiv">
<asp:Button ID="btnSave" runat="server" Text="Save" CssClass="btnSave" Width="90px" Visible="true" OnClick="btnSave_Click"/>
</div>
<div class="btnDiv">
<asp:Button ID="btnCancel" runat="server" Text="Clear" CssClass="btnCancel" Width="90px" Visible="true" OnClick="btnCancel_Click"/>
</div>
</div>
在 C# 中单击保存的按钮后,我想找出用户输入的值,但它总是返回 null:
protected void btnSave_Click(object sender, EventArgs e)
{
TextBox txtSignQuantity;
string tempSignQuantity;
try
{
foreach (DataListItem item in SignsList.Items)
{
txtSignQuantity = item.FindControl("txtSignQuantity") as TextBox;
tempSignQuantity = txtSignQuantity.Text;
}
}
catch (Exception ex)
{
Console.WriteLine(ex);
}
}
我还检查了 SignsList.Items 的计数为 8,所以我知道它正在检索正确的信息。抱歉,我以前从未使用过数据列表,所以我不太确定如何进行此操作...
最佳答案
简短的回答是回发时的数据绑定(bind)导致了问题。在进行数据绑定(bind)之前检查 Page.IsPostBack
属性:
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
//fill the datalist for the Signs Table
string tCallFrom = "Program." + System.Reflection.MethodBase.GetCurrentMethod().Name;
string tQry = @"SELECT * FROM [js_Signs]";
DataTable tblSigns = objCommMethods.fReturnTableFromQry(clsDBSelect.enumDBSelect.ProjectMaster, tQry, tCallFrom);
SignsList.DataSource = tblSigns;
SignsList.DataBind();
}
}
ASP.NET WebForms 试图抽象出这样一个事实:用于呈现页面的控件实例与处理回发事件时所具有的实例不同。数据绑定(bind)复合了抽象,因为它必须创建控件来响应 DataBind
调用,然后在回发时,根据它保存的 ViewState
重新创建它们。
从 ViewState
初始化控件发生在 Init
事件上,因此当 Load
事件稍后在页面生命周期中触发并且您调用 DataBind
在控件上,它恢复的所有内容都会被清除并重新创建。
至于为什么你得到null
,可能是控件被删除但没有重新创建;这可能与第二次数据绑定(bind)后未重新连接的其他事件处理程序有关。
关于c# - FindControl() 始终从 DataList 文本框返回 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66071518/