2011-08-10 95 views
1

所以我们走吧。我在“客户”记录上有两个下拉列表。第一个叫做“Store”。第二个叫做“StoreWarehouse”。当用户选择一个“Store”值时,会根据用户的选择过滤“StoreWarehouse”下拉列表。我通过jQuery和AJAX完成了过滤。我正在使用一个ListView,这是在InsertItemTemplate中。DropDownList的SelectedValue为空 - 为什么?

下面的代码为:

 function StoreWarehouseLoad(store_ddl) { 
     var store_id = store_ddl.options[store_ddl.selectedIndex].value; 
     var js = JSON.stringify({ store: store_id }); 
     $.ajax({ 
      url: baseUrl + '/AutoComplete/StoreList.asmx/GetStores', 
      data: js, 
      dataType: "json", 
      type: "POST", 
      contentType: "application/json; charset=utf-8", 
      success: function (data) { 
       var ddl = $("#StoreWarehouse_ddl"); 
       ddl.find('option').remove(); 
       $(data.d).each(function (index) { 
        ddl.append('<option value="' + this.WarehouseID + '">' + this.WarehouseID + '</option>'); 
       }); 
       switch (culture) { 
        case "en-CA": 
         ddl.val(store_id.substring(0, 2) + "I"); 
         break; 
        case "en-US": 
         ddl.val('001'); 
         break; 
        default: 
         alert("The default warehouse cannot be set because there's something wrong with the current culture..."); 
         break; 
       } 
      }, 
      error: function (XMLHttpRequest, textStatus, errorThrown) { 
       sendErrorEmail(window.location.href, 'Customers.aspx.StoreWarehouseLoad', XMLHttpRequest); 
      } 
     }); 
    } 

这个JavaScript调用加载基于“存储”下拉列表中选择的选择“StoreWarehouse”下拉列表中的Web服务。这一切都非常好。

我的问题是当我保存一条记录。假设我将为客户输入新记录,输入所有值(以及Store and StoreWarehouse下拉列表)。我将点击“保存” - 然后应该将数据保存到数据库。我的问题是StoreWarehouse下拉列表中的SelectedValue没有进入业务层。我甚至为ListView的“OnInserting”事件捕获了e.Values,而e.Values [“DefaultWarehouseId”]为null。这里是我的aspx页面的两个下拉列表:

<div class="labelAndTextboxContainer"> 
          <div class="labelContainer"> 
           <asp:Label CssClass="rightFloat" ID="StoreId_lbl" runat="server" Text="Branch:"></asp:Label><br /> 
          </div> 
          <div class="textboxContainer"> 
           <asp:DropDownList ID="Store_ddl" runat="server" DataSourceID="StoreDataSource" AppendDataBoundItems="true" 
            onchange="StoreWarehouseLoad(this);" DataValueField="StoreID" DataTextField="StoreID" 
            CssClass="leftFloat" Font-Size="Smaller" SelectedValue='<%# Bind("StoreID") %>'> 
            <asp:ListItem /> 
           </asp:DropDownList> 
           <asp:RequiredFieldValidator ID="StoreId_ddl_rfv" runat="server" ControlToValidate="Store_ddl" 
            Text="*" ForeColor="Red" /> 
          </div> 
         </div> 
         <br class="clear" /> 
         <div class="labelAndTextboxContainer"> 
          <div class="labelContainer"> 
           <asp:Label CssClass="rightFloat" ID="StoreWarehouse_lbl" runat="server" Text="Def. Store Warehouse:"></asp:Label><br /> 
          </div> 
          <div class="textboxContainer"> 
           <asp:DropDownList ID="StoreWarehouse_ddl" runat="server" CssClass="leftFloat" Font-Size="Smaller" 
            OnDataBound="StoreWarehouse_ddl_OnDataBound" onchange="changeWarehouse();" SelectedValue='<%# Bind("DefaultWarehouseId") %>' 
            ClientIDMode="Static"> 
           </asp:DropDownList> 
          </div> 
         </div> 

正如你所看到的,我有设定为<%#绑定(“DefaultwarehouseId”)%>的StoreWarehouse下拉列表中的“的SelectedValue” 。由于某种原因,DefaultWarehouseId没有选择StoreWarehouse的下拉列表中的值。

有趣的是,我可以把下列我的JavaScript如上图所示,它提醒我,下拉列表中选定的值:

alert("store warehouse selected is " + $("#StoreWarehouse_ddl").val()); 

为什么没有在服务器端代码采摘增加这个值?

非常感谢!

迈克

回答

0

我会怀疑这个问题是因为你填充你的DropDownList控制客户端。当你回发服务器端时忽略你的JavaScript生成的项目,因为它重建基于隐藏的ControlState的控件。

如果你想在WebForms中使用这种类型的ajax,我会查看提供的ajax控件,并使用更新面板。

+0

谢谢,是的,这是有道理的。 – user888636

2

赞@ shiznit123表示这些信息存储在ControlState中。我更喜欢MVC框架而不是WebForms的原因之一。

但是,在您的情况下,我相信您可以使用隐藏字段来解决此问题。 asp:hidden。您只需直接管理该值。所以当用户选择下拉列表中的一个项目时,更新相应的隐藏字段。

相关问题