Rozwijam formularz i używam autouzupełniania interfejsu użytkownika jQuery. Gdy użytkownik wybierze opcję, chcę, aby zaznaczenie pojawiło się w zakresie dołączonym do <p>
tagu nadrzędnego . Następnie chcę, aby pole zostało wyczyszczone, a nie wypełnione zaznaczeniem.
Wydaje mi się, że rozpiętość jest w porządku, ale nie mogę oczyścić pola.
Jak anulować domyślną akcję wyboru funkcji autouzupełniania interfejsu użytkownika jQuery?
Oto mój kod:
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>");
}
});
Po prostu działanie $(this).val("");
nie działa. Irytujące jest to, że prawie dokładna funkcja działa dobrze, jeśli zignoruję autouzupełnianie i po prostu podejmę działanie, gdy użytkownik wpisze przecinek jako taki:
$('[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>");
}
});
Prawdziwym rezultatem końcowym jest autouzupełnianie do pracy z wieloma zaznaczeniami. Jeśli ktoś ma jakieś sugestie, byłby mile widziany.