1

我正在处理 ASP.NET 4 中的 Web 表单,我需要根据下拉列表中的选择在表中显示一长串条目。我有以下 ASPX 和代码隐藏:

<form method="post" runat="server" >
    <asp:ScriptManager runat="server" ID="mScriptManager"></asp:ScriptManager>
    <asp:UpdatePanel ID="pnlLocalizationInfo" runat="server" >
        <ContentTemplate>
            <div id="selectLanguage">
                <p>Pick language
                    <asp:DropDownList ID="ddllanguage" runat="server" OnTextChanged="SelectLanguage" AutoPostBack="true" />
                </p>
            </div>
            <div id="languageTable">
        <asp:Repeater id="repTable" runat="server" OnItemDataBound="AddTableData" >
            <HeaderTemplate>
            Language: 
            <asp:Label ID="lbllanguageTable" runat="server" />
            <table>
                <tr>
                    <th>Name</th>
                    <th>Value</th>
                </tr>
            </HeaderTemplate>
            <ItemTemplate>
                <tr>
                    <td>
                        <asp:Label ID="lbltableNameLocalization" runat="server" />
                        <asp:HiddenField ID="hfnameLocalization" runat="server" Value='<%#((Localization)Container.DataItem).Id %>' />
                    </td>
                    <td>
                        <asp:TextBox ID="txttableValueLocalization" runat="server" />
                    </td>
                </tr>
            </ItemTemplate>
            <FooterTemplate>
            </table>
            </FooterTemplate>
        </asp:Repeater>
        <asp:Button ID="btnupdateLocalization" runat="server" OnClick="UpdateLocalization" Text="Save" />           
            </div>                
        </ContentTemplate>
    </asp:UpdatePanel>
</form>

public void SelectLanguage(object sender, EventArgs e)
{
    string lang = ddllanguage.SelectedValue;
    if (ddllanguage.SelectedIndex != 0)
    {
        repTable.DataSource = Data.GetAllLocalizations(lang);
        repTable.DataBind();
    }
}

该调用GetAllLocalizations返回一个 ArrayList,其中包含稍后用于填充 Repeater 表的数据库实体。但是,该DataBind函数在调用时会挂起,因此只要更改下拉列表,整个表单就会停止工作。如果数据绑定是在页面加载时完成的,而不是在事件处理程序中,它可以正常工作。我有另一个使用相同方法的旧页面(下拉列表的事件处理程序中的数据绑定)并且它可以顺利工作。

有任何想法吗?

4

2 回答 2

1

我会在一定程度上同意 Jekom。

也可以不直接显示数据库结果吗?为什么它们首先被传递到数组中?

我发现使用中继器或任何数据显示时,都是在 SQL 中创建存储过程或函数并允许服务器完成工作。

您可能在这样做时遇到困难的原因是您要求客户计算所有信息,并且您说有大量数据需要处理。

没有更多信息很难更具体

于 2013-06-04T12:32:41.447 回答
1

我看到你打电话OnItemDataBound,我会检查这个事件,可能有一些过程需要时间才能完成,或者可能处于无限循环中。

于 2013-06-04T12:16:29.967 回答