estado siguiendo la documentación del sitio de la interfaz de usuario, y miré una serie de tutoriales y conseguí que mi código funcionara, ajax está en la lista de términos que quiero y puede seleccionar uno y coloca el valor y luego ",". Sin embargo, luego no vuelve a solicitar un segundo valor.jQuery autocompletar con múltiples valores ajax
Además, cuando ingreso un popup parcial y digamos 10 entradas, la tabulación simplemente va al siguiente campo de formulario, ¿no estoy seguro de qué pasa con mi .bind, quizás una configuración? Si a alguien no le importaría echar un vistazo, ¡sería muy apreciado!
function split(val) {
return val.split(/,\s*/);
}
function extractLast(term) {
return split(term).pop();
}
jQuery('#tagSearch')
.bind('keydown', function(event) {
if (event.keyCode === jQuery.ui.keyCode.TAB &&
jQuery(this).data('autocomplete').menu.active) {
event.preventDefault();
}
})
.autocomplete({
autoFocus: true,
source: function(request, add) {
console.log('source');
jQuery.getJSON('/get-tags-like.php?term_start=' + request.term, function(response) {
var possibleTerms = [];
jQuery.each(response, function(i, val) {
possibleTerms.push(val.name + ' ' + '(' + val.count + ')');
});
add(jQuery.map(possibleTerms, function(item) {
console.log(possibleTerms);
return item;
}));
});
},
focus: function() {
console.log('focus');
return false;
},
select: function(event, ui) {
console.log('select');
var terms = split(this.value);
terms.pop();
terms.push(ui.item.value);
terms.push('');
this.value = terms.join(',');
// At this point, example:
// Sony (5)
var currentVal = this.value;
// Sony (5) - Gets inserted as "Sony"
currentVal = currentVal.replace(/\s\(.\)/, '');
this.value = currentVal;
return false;
},
minLength: 2
});
¿El enlace de autocompletar del evento de tecla interferiría con el suyo? –