我正在使用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
函数会在调用时挂起,因此只要更改下拉列表,整个表单就会停止工作。如果数据绑定是在页面加载而不是在事件处理程序中完成的,那么它可以正常工作。我有另一个较旧的页面使用相同的方法(下拉列表的事件处理程序中的数据绑定),它没有任何障碍。
有什么想法吗?
答案 0 :(得分:1)
我看到你打电话给OnItemDataBound
,我会检查这个事件,可能有一些过程需要时间才能完成,或者可能处于无限循环中。
答案 1 :(得分:1)
我会在一定程度上同意Jekom。
您也可以直接显示数据库结果吗?为什么他们首先被传递到数组?
我发现使用转发器或任何数据显示是在SQL中创建存储过程或函数,并允许服务器完成工作。
您可能遇到困难的原因是您要求客户解决所有信息,并说您需要处理大量数据。
如果没有更多信息,很难更具体化