2

我目前在keyup()活动中遇到问题。

当我对.change()事件使用自动完成时,一切正常。但是我认为,自动完成的建议仅在失去该领域的焦点时才显示,这是正常的。

问题是当我使用该.keyup()事件时,会显示建议,但是当您单击建议列表中的项目时,该项目不会放在文本字段中。

与将change()建议设置到字段的功能不同。

 jQuery(document).ready(function() {  
        jQuery("#customfield_10000").keyup(function(e){
                            teller = teller + 1;
                            if(teller % 2 == 0){
                            if(e.keyCode == 13)
                            {
                                jQuery("#customfield_10001").focus();
                            }    

            crmAccount = jQuery(this).val();
            lijstAccounts.length = 0;

                    jQuery.ajax({
                        url: "http://"+serverIp+"/getAllAccountNamesJsonP?jsonp_callback=?",
                        dataType: 'jsonp',
                        jsonp: "jsonp_callback",
                        data: {
                            featureClass: "P",
                            style: "full",
                            maxRows: 12,
                            name_startsWith: jQuery(this).val(),
                                                            crm_acc: crmAccount,
                            },
                            success: function( data ) {
                                lijstAccounts.length = 0;
                                 jQuery.map( data, function( item ) {
                                                            lijstAccounts.push(item);
                                                            jQuery('#customfield_10000').trigger(
                                                                'setSuggestions',
                                                            { result : textext.itemManager().filter(lijstAccounts, query)

                                                                                                                            }
                                                            );              
                                    return {
                                        label: item.label,
                                        value: item.value    
                                    }
                                });
                            }
                        }); 
                            }
        });


             jQuery('#customfield_10000').textext({
                plugins : 'autocomplete'
                }).bind('getSuggestions', function(e, data)
                    {

                        textext = jQuery(e.target).textext()[0],
                        query = (data ? data.query : '') || '';

                    });
});
4

2 回答 2

4

你为什么不把两者都绑定?根据您的 jQuery 版本:

jQuery 1.7+

$(selector).on('keyup change', function() {});

其他

$(selector).bind('keyup change', function() {});
于 2012-05-21T07:24:50.330 回答
1

实际上我今天遇到了类似的问题,我将选择器从引用输入字段的 id 更改为如下名称:

$("input:text[name=search-box]").keyup(function(){
    //Code
});

奇怪的是,在我进行更改后一切正常。希望这对你也有效。

于 2012-05-21T10:13:02.277 回答