Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/37.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# FindControl()始终从DataList文本框返回null_C#_Asp.net_Datalist - Fatal编程技术网

C# FindControl()始终从DataList文本框返回null

C# FindControl()始终从DataList文本框返回null,c#,asp.net,datalist,C#,Asp.net,Datalist,我在一个SQL表中有8个项目,包括描述、项目编号和ImagePath protected void Page_Load(object sender, EventArgs e) { //fill the datalist for the Signs Table string tCallFrom = "Program." + System.Reflection.MethodBase.GetCurrentMethod().Name;

我在一个SQL表中有8个项目,包括描述、项目编号和ImagePath

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();
    }
我正在使用数据列表显示所有项目以及一个文本框,该文本框允许用户输入他们想要的项目数:

    <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>

我还检查了SignsList.Items的计数为8,因此我知道它正在检索正确的信息。很抱歉,我以前从未使用过数据列表,因此我不确定如何执行此操作…

简单的回答是回发上的数据绑定导致了此问题。在执行数据绑定之前,请检查
页.IsPostBack
属性:

受保护的无效页面加载(对象发送方,事件参数e)
{
如果(!Page.IsPostBack)
{
//填写符号表的数据列表
字符串tCallFrom=“Program.”+System.Reflection.MethodBase.GetCurrentMethod().Name;
字符串tQry=@“从[js_符号]中选择*”;
DataTable tblSigns=objCommMethods.fReturnTableFromQry(clsDBSelect.enumDBSelect.ProjectMaster、tQry、tCallFrom);
SignsList.DataSource=tblSigns;
SignsList.DataBind();
}
}
ASP.NET WebForms试图抽象出一个事实,即用于呈现页面的控件实例与处理回发事件时的实例不同。数据绑定使抽象复杂化,因为它必须创建控件以响应
DataBind
调用,然后在回发时,根据保存的
ViewState
重新创建控件

ViewState
初始化控件发生在
Init
事件上,因此当
Load
事件在页面生命周期的晚些时候被触发,并且您在控件上调用
DataBind
时,它还原的所有内容都会被清除并重新创建


至于为什么会得到
null
,可能是控件被删除了,但没有重新创建;这可能与第二次数据绑定后没有重新布线的其他事件处理程序有关。

该代码的上下文是什么?它是否在加载页面中?在
事件处理程序中单击
事件处理程序?哦,对不起,我应该把它放进去。它位于一个点击式句柄中,请在帖子中显示完整的事件处理程序方法。此外,它可能有助于显示数据绑定到DataList的位置和方式。IIRC,您不应该在回发时进行数据绑定。如果(!Page.IsPostBack){…}
我认为这里没有足够的信息来确定为什么回发上的数据绑定使它无法找到控件,请将数据绑定包装到
if(!Page.IsPostBack){…}
。您必须设置一些断点并调查
项随时间的变化。我希望我的回答的后半部分能给你足够的信息,让你知道如何去做。
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);
        }   
}