C# 下拉列表';s SelectedValue为空--为什么?
我们开始吧。我在“客户”记录上有两个下拉列表。第一个叫做“商店”。第二个叫做“仓库”。当用户选择“Store”值时,该值将根据用户的选择过滤“StoreWarehouse”下拉列表。我已经通过jQuery和AJAX完成了过滤。我使用的是ListView,它位于InsertItemTemplate中 下面是代码:C# 下拉列表';s SelectedValue为空--为什么?,c#,asp.net,drop-down-menu,selectedvalue,C#,Asp.net,Drop Down Menu,Selectedvalue,我们开始吧。我在“客户”记录上有两个下拉列表。第一个叫做“商店”。第二个叫做“仓库”。当用户选择“Store”值时,该值将根据用户的选择过滤“StoreWarehouse”下拉列表。我已经通过jQuery和AJAX完成了过滤。我使用的是ListView,它位于InsertItemTemplate中 下面是代码: function StoreWarehouseLoad(store_ddl) { var store_id = store_ddl.options[sto
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);
}
});
}
为什么服务器端代码没有获取这个值
非常感谢
Mike我怀疑问题是因为您正在填充DropDownList控件客户端。回发时,服务器端会忽略javascript生成的项,因为它会根据隐藏的ControlState重建控件
如果您希望在WebForms中使用ajax实现这类功能,我会查看提供的ajax控件并使用更新面板。如@shiznit123所述,此信息存储在ControlState中。与WebForms相比,我更喜欢MVC框架的原因之一
但是,在您的情况下,我相信您可以使用隐藏字段绕过此问题<代码>asp:隐藏。你只需要直接管理价值。因此,当用户在下拉列表中选择一个项目时,更新相应的隐藏字段。谢谢,是的,这很有意义。
<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>
alert("store warehouse selected is " + $("#StoreWarehouse_ddl").val());