0

我有一个奇怪的组合框。

这是我的标记

<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);
        }
 }
 );
});

这是我的问题:

  1. 页面加载时将一项插入组合框并选中
  2. 单击进入组合框并按退格键
  3. 单击组合框

预期:ComboBox 触发 selectedIndexChanged 事件,因为我们现在没有选择项目

实际:项目在没有触发事件的情况下被移除

有趣的是,如果您单击框并关闭而不删除项目。然后单击并删除它,事件正确触发。

有任何想法吗?

4

1 回答 1

0

我现在有一个解决方法,看起来我想要的是组合框不受支持的行为。

于 2013-07-05T13:29:34.797 回答