jquery change()vs keyup()

问题描述 投票:1回答: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 : '') || '';

                    });
});
jquery jquery-plugins
2个回答
2
投票

您为什么不只捆绑两个?取决于您的jQuery版本:

jQuery 1.7 +

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

其他

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

1
投票

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

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

很奇怪,我进行更改后,一切正常。希望这对您也有用。

© www.soinside.com 2019 - 2024. All rights reserved.