没有页面刷新事件的OnSelectedIndexChanged下拉列表

时间:2015-04-18 16:36:08

标签: asp.net updatepanel page-refresh scriptmanager selectedindexchanged

我正在使用下拉列表中的脚本管理器+更新面板,因此当用户从中选择一些内容时,页面将无法刷新(这是我的目标)。

以下是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>

1 个答案:

答案 0 :(得分:0)

在进行编辑后告诉updatepanel刷新,因为updatemode在ur标记中设置为条件。

 UpdatePanel1.Update()