我正在使用下拉列表中的脚本管理器+更新面板,因此当用户从中选择一些内容时,页面将无法刷新(这是我的目标)。
以下是HTML代码:
<asp:ScriptManager ID="ScriptManager1" runat="server"></asp:ScriptManager>
<asp:ListView ID="listProducts" runat="server" DataKeyNames="ProductID" OnItemDataBound="listProducts_ItemDataBound" OnItemCommand="listProducts_ItemCommand">
<ItemTemplate>
<div class="productoverlay">
<div class="col-lg-4 proizvod">
<div class="product">
<div class="glow"></div>
<img src='<%# "../productimg/" + Eval("FileName")%>' alt='<%# Eval("ProductName") %>'/>
</div>
</div>
<div class="col-lg-1 price">
<asp:Label ID="lblPrice" runat="server" Text=""></asp:Label>
</div>
<div class="col-lg-7 pushtop">
<h1><%# Eval("ProductName") %></h1>
<p>Description: </p>
<p><%# Eval("ProductDescription") %></p>
<p>Quantity: </p><asp:TextBox ID="txtPackageQuantity" TextMode="Number" runat="server"></asp:TextBox>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional">
<Triggers>
<asp:AsyncPostBackTrigger controlid="DropDownList1" eventname="SelectedIndexChanged" />
</Triggers>
<ContentTemplate>
<asp:DropDownList ID="DropDownList1" AutoPostBack="true" OnSelectedIndexChanged="DropDownList1_SelectedIndexChanged" runat="server"></asp:DropDownList>
</ContentTemplate>
</asp:UpdatePanel>
<asp:Button ID="Button1" runat="server" Text="Add to cart" CommandName="AddToCart" CommandArgument='<%# Eval("ProductID")%>'/>
</div>
</div>
</ItemTemplate>
</asp:ListView>
这是OnSelectedIndexChanged事件的代码:
protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
var ddl = sender as DropDownList;
var val = int.Parse(ddl.SelectedValue);
rlsp_PrCategories_ByID_Result pr = ServiceClass.ProductCatByID(val);
Label lblPrice = ddl.Parent.FindControl("lblPrice") as Label;
if(pr!=null)
lblPrice.Text = "$ " + pr.Price;
}
现在的问题是,当我添加脚本管理器+更新面板(异步回发触发器)时,现在当我从下拉列表中选择一些内容时,页面不会刷新,但标签也没有显示任何内容(当我从下拉菜单中选择一些东西时它应该改变价格)。
我在这里做错了什么?有人可以帮助我吗?
P.S。我刚刚检查了当用户选择某事时事件是否会激活,是的,它会激活,但我似乎无法看到该标签的内容(它没有在页面上打印出来)......?< / p>
答案 0 :(得分:0)
在进行编辑后告诉updatepanel刷新,因为updatemode在ur标记中设置为条件。
UpdatePanel1.Update()