我正在使用jquery autocomplete,我从rails应用程序上的ruby填充,我正在创建一个自定义的autcomplete,如下所示:
$.widget( "custom.code_complete", $.ui.autocomplete, {
_renderMenu: function( ul, items ) {
var self = this,
currentCategory = "";
$ul = ul;
$.each( items, function( index, item ) {
if ( item.category != currentCategory ) {
ul.append( "<li class='ui-autocomplete-category'>" + item.category + "</li>" );
currentCategory = item.category;
}
self._renderItem( ul, item );
});
}
});
$("#r-code").code_complete({
source: "URL",
minLength: 2,
select: function(event, ui) {
$(".button-row").fadeIn();
get_details(ui.item.url);
}
});
我正在将用户从另一个页面重定向到具有自动填充表单的页面,其中URL中的参数是用于搜索的代码,这里是用于搜索的JS:
function ac_search(code) {
$("#r-code").val(code);
$("#r-code").code_complete('search', code);
}
这将完美地执行搜索并显示结果的下拉列表。我试图让脚本然后选择列表中的第一个结果。我试过通过选择器来做到这一点:
$(".ui-menu-item:first a").click();
这会在自动填充列表中找到正确的元素,但是当我尝试模拟单击时会出现此错误:
TypeError: ui.item is null
是否可以通过编程方式点击自动填充结果列表中的第一项?
干杯
EEF
答案 0 :(得分:19)
$( el ).autocomplete({
autoFocus: true
});
答案 1 :(得分:15)
使用autoFocus:true
$( el ).autocomplete({
autoFocus: true
...
});