我在手动触发 jQuery 自动完成框时遇到问题。源带有 $.ajax 并返回 json。同样在“打开”功能上,我将一些自定义项目附加到框中。现在我需要的是,当您单击输入时,将看到自动完成框。它不需要搜索或任何东西。只需显示带有自定义附加项目的框。
我试过 minLength: 0 和 $(this).autocomplete('search', ''); 但这些都行不通。任何帮助,将不胜感激。
当前代码:
$(".searchBox").autocomplete({
delay: 300,
open: function() {
$('.ui-autocomplete').prepend('<li class="nav-button ui-menu-close"><a href="#">×</a></li>');
var position = $('.ui-autocomplete').position(),
left = position.left, top = position.right;
$('.ui-autocomplete').css({left: 0,
width: "auto",
'z-index': 1000
});
$('.ui-menu-close').on('click', function() {
$('.searchBox').autocomplete('close');
});
},
source: function(request, response)
{
$.ajax({
url: '/search',
data: {
'ajax' : 1,
'query': request.term
},
timeout: 3000,
dataType: 'json',
success: function(data) {
console.log(data)
},
});
},
minLength: 0
}).focus(function() {
$(this).data('autocomplete')._trigger('open');
$(this).trigger('keydown.autocomplete');
});
谢谢你。