Sto sviluppando un modulo e utilizzo il completamento automatico dell'interfaccia utente jQuery. Quando l'utente seleziona un'opzione, desidero che la selezione venga visualizzata in un intervallo aggiunto al <p>
tag principale . Quindi voglio che il campo si cancelli piuttosto che essere popolato con la selezione.
Ho la durata che sembra a posto, ma non riesco a liberare il campo.
Come si annulla l'azione di selezione predefinita del completamento automatico dell'interfaccia utente di jQuery?
Ecco il mio codice:
var availableTags = ["cheese", "milk", "dairy", "meat", "vegetables", "fruit", "grains"];
$("[id^=item-tag-]").autocomplete({
source: availableTags,
select: function(){
var newTag = $(this).val();
$(this).val("");
$(this).parent().append("<span>" + newTag + "<a href=\"#\">[x]</a> </span>");
}
});
Il semplice fatto $(this).val("");
non funziona. Ciò che è esasperante è che quasi la funzione esatta funziona bene se ignoro il completamento automatico e agisco solo quando l'utente digita una virgola come tale:
$('[id^=item-tag-]').keyup(function(e) {
if(e.keyCode == 188) {
var newTag = $(this).val().slice(0,-1);
$(this).val('');
$(this).parent().append("<span>" + newTag + "<a href=\"#\">[x]</a> </span>");
}
});
Il vero risultato finale è ottenere il completamento automatico per lavorare con più selezioni. Se qualcuno ha qualche suggerimento in merito, sarebbe il benvenuto.