我有一个奇怪的组合框。
这是我的标记
<telerik:RadComboBox
runat="server"
id="rcbSite"
width="210px"
enableloadondemand="true"
onclientitemsrequesting="rcbSite_OnClientItemsRequesting"
showmoreresultsbox="True"
enablevirtualscrolling="True" >
<WebServiceSettings Method="GetSitesComboBoxDataByCustomerId" Path="/Services/ClientSideDataService.asmx" />
</telerik:RadComboBox>
很合理,comboBox 与 Web 服务相关联。
onItemsRequesting 函数将一些额外的数据位添加到我们需要的组合框上下文中。
function rcbSite_OnClientItemsRequesting(sender, eventArgs) {
//Get the selected customer
var selectedCustomerId = $('#<%= CustomerDropDownId %> option:selected').attr('value');
var context = eventArgs.get_context();
//Set filter text
context["FilterString"] = eventArgs.get_text();
context["CustomerId"] = selectedCustomerId;
}
在我的代码隐藏中,如果之前选择了一个项目,我会创建并选择一个项目。
if (siteId.HasValue)
{
rcbSite.Items.Add(SiteManager.GetComboBoxItemBySiteId(siteId.Value));
rcbSite.SelectedValue = siteId.Value.ToString();
}
最后在 document.ready 上,我将一个 selctedIndexChanged 事件附加到组合框
//Site Changed
Sys.Application.add_load(function(){
//If the combo box has items in it, select the first one
//Selecting first item client side ensures that address fields are refreshed when binding individual item to combo box on initial page load
var combo = $find("<%= rcbSite.ClientID %>");
if (combo.get_items().getItem(0)) {
combo.trackChanges();
combo.get_items().getItem(0).select();
combo.commitChanges();
}
$find("<%= rcbSite.ClientID %>").add_selectedIndexChanged(
function (sender, eventArgs) {
var item = eventArgs.get_item();
var addressFormFields = new InventoryAddressFields("<%= ddlAddressType.ClientID %>", "<%= txtAttenTo.ClientID %>", "<%= txtAddress1.ClientID %>",
"<%= txtAddress2.ClientID %>", "<%= txtCity.ClientID %>", "<%= ddlCountry.ClientID %>",
"<%= ddlState.ClientID %>", "<%= ddlCounty.ClientID %>", "<%= txtPostalCode.ClientID %>",
"<%= txtPostalCodePlus4.ClientID %>", "<%= txtPhone.ClientID %>", "<%= txtFax.ClientID %>",
"<%= ddlTimezone.ClientID %>", "<%= chkObserveDST.ClientID %>", "<%= ddlVerificationStatus.ClientID %>");
if (item) {
var selectedSiteId = item.get_value();
GetAddressBySiteId(addressFormFields, selectedSiteId);
}
else
{
clearAddressFields(addressFormFields);
}
}
);
});
这是我的问题:
- 页面加载时将一项插入组合框并选中
- 单击进入组合框并按退格键
- 单击组合框
预期:ComboBox 触发 selectedIndexChanged 事件,因为我们现在没有选择项目
实际:项目在没有触发事件的情况下被移除
有趣的是,如果您单击框并关闭而不删除项目。然后单击并删除它,事件正确触发。
有任何想法吗?